* solib-svr4.c (BKPT_AT_SYMBOL): Remove, always defined.
[deliverable/binutils-gdb.git] / bfd / coffcode.h
CommitLineData
252b5132 1/* Support for the generic parts of most COFF variants, for BFD.
7898deda 2 Copyright 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999,
2b5c217d 3 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008
252b5132
RH
4 Free Software Foundation, Inc.
5 Written by Cygnus Support.
6
ed781d5d 7 This file is part of BFD, the Binary File Descriptor library.
252b5132 8
ed781d5d
NC
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
cd123cb7 11 the Free Software Foundation; either version 3 of the License, or
ed781d5d 12 (at your option) any later version.
252b5132 13
ed781d5d
NC
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
252b5132 18
ed781d5d
NC
19 You should have received a copy of the GNU General Public License
20 along with this program; if not, write to the Free Software
cd123cb7
NC
21 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
22 MA 02110-1301, USA. */
252b5132 23
7920ce38
NC
24/* Most of this hacked by Steve Chamberlain,
25 sac@cygnus.com. */
252b5132 26/*
252b5132
RH
27SECTION
28 coff backends
29
30 BFD supports a number of different flavours of coff format.
31 The major differences between formats are the sizes and
32 alignments of fields in structures on disk, and the occasional
33 extra field.
34
35 Coff in all its varieties is implemented with a few common
36 files and a number of implementation specific files. For
37 example, The 88k bcs coff format is implemented in the file
38 @file{coff-m88k.c}. This file @code{#include}s
39 @file{coff/m88k.h} which defines the external structure of the
40 coff format for the 88k, and @file{coff/internal.h} which
41 defines the internal structure. @file{coff-m88k.c} also
42 defines the relocations used by the 88k format
43 @xref{Relocations}.
44
45 The Intel i960 processor version of coff is implemented in
46 @file{coff-i960.c}. This file has the same structure as
47 @file{coff-m88k.c}, except that it includes @file{coff/i960.h}
48 rather than @file{coff-m88k.h}.
49
50SUBSECTION
51 Porting to a new version of coff
52
53 The recommended method is to select from the existing
54 implementations the version of coff which is most like the one
55 you want to use. For example, we'll say that i386 coff is
56 the one you select, and that your coff flavour is called foo.
57 Copy @file{i386coff.c} to @file{foocoff.c}, copy
58 @file{../include/coff/i386.h} to @file{../include/coff/foo.h},
59 and add the lines to @file{targets.c} and @file{Makefile.in}
60 so that your new back end is used. Alter the shapes of the
61 structures in @file{../include/coff/foo.h} so that they match
62 what you need. You will probably also have to add
63 @code{#ifdef}s to the code in @file{coff/internal.h} and
64 @file{coffcode.h} if your version of coff is too wild.
65
66 You can verify that your new BFD backend works quite simply by
67 building @file{objdump} from the @file{binutils} directory,
68 and making sure that its version of what's going on and your
69 host system's idea (assuming it has the pretty standard coff
70 dump utility, usually called @code{att-dump} or just
71 @code{dump}) are the same. Then clean up your code, and send
72 what you've done to Cygnus. Then your stuff will be in the
73 next release, and you won't have to keep integrating it.
74
75SUBSECTION
76 How the coff backend works
77
78SUBSUBSECTION
79 File layout
80
81 The Coff backend is split into generic routines that are
82 applicable to any Coff target and routines that are specific
83 to a particular target. The target-specific routines are
84 further split into ones which are basically the same for all
85 Coff targets except that they use the external symbol format
86 or use different values for certain constants.
87
88 The generic routines are in @file{coffgen.c}. These routines
89 work for any Coff target. They use some hooks into the target
90 specific code; the hooks are in a @code{bfd_coff_backend_data}
91 structure, one of which exists for each target.
92
93 The essentially similar target-specific routines are in
94 @file{coffcode.h}. This header file includes executable C code.
95 The various Coff targets first include the appropriate Coff
96 header file, make any special defines that are needed, and
97 then include @file{coffcode.h}.
98
99 Some of the Coff targets then also have additional routines in
100 the target source file itself.
101
102 For example, @file{coff-i960.c} includes
103 @file{coff/internal.h} and @file{coff/i960.h}. It then
104 defines a few constants, such as @code{I960}, and includes
105 @file{coffcode.h}. Since the i960 has complex relocation
106 types, @file{coff-i960.c} also includes some code to
107 manipulate the i960 relocs. This code is not in
108 @file{coffcode.h} because it would not be used by any other
109 target.
110
111SUBSUBSECTION
112 Bit twiddling
113
114 Each flavour of coff supported in BFD has its own header file
115 describing the external layout of the structures. There is also
116 an internal description of the coff layout, in
117 @file{coff/internal.h}. A major function of the
118 coff backend is swapping the bytes and twiddling the bits to
119 translate the external form of the structures into the normal
120 internal form. This is all performed in the
121 @code{bfd_swap}_@i{thing}_@i{direction} routines. Some
122 elements are different sizes between different versions of
123 coff; it is the duty of the coff version specific include file
124 to override the definitions of various packing routines in
125 @file{coffcode.h}. E.g., the size of line number entry in coff is
126 sometimes 16 bits, and sometimes 32 bits. @code{#define}ing
127 @code{PUT_LNSZ_LNNO} and @code{GET_LNSZ_LNNO} will select the
128 correct one. No doubt, some day someone will find a version of
129 coff which has a varying field size not catered to at the
130 moment. To port BFD, that person will have to add more @code{#defines}.
131 Three of the bit twiddling routines are exported to
132 @code{gdb}; @code{coff_swap_aux_in}, @code{coff_swap_sym_in}
00692651 133 and @code{coff_swap_lineno_in}. @code{GDB} reads the symbol
252b5132
RH
134 table on its own, but uses BFD to fix things up. More of the
135 bit twiddlers are exported for @code{gas};
136 @code{coff_swap_aux_out}, @code{coff_swap_sym_out},
137 @code{coff_swap_lineno_out}, @code{coff_swap_reloc_out},
138 @code{coff_swap_filehdr_out}, @code{coff_swap_aouthdr_out},
139 @code{coff_swap_scnhdr_out}. @code{Gas} currently keeps track
140 of all the symbol table and reloc drudgery itself, thereby
141 saving the internal BFD overhead, but uses BFD to swap things
142 on the way out, making cross ports much safer. Doing so also
143 allows BFD (and thus the linker) to use the same header files
144 as @code{gas}, which makes one avenue to disaster disappear.
145
146SUBSUBSECTION
147 Symbol reading
148
149 The simple canonical form for symbols used by BFD is not rich
150 enough to keep all the information available in a coff symbol
151 table. The back end gets around this problem by keeping the original
152 symbol table around, "behind the scenes".
153
154 When a symbol table is requested (through a call to
155 @code{bfd_canonicalize_symtab}), a request gets through to
156 @code{coff_get_normalized_symtab}. This reads the symbol table from
157 the coff file and swaps all the structures inside into the
158 internal form. It also fixes up all the pointers in the table
159 (represented in the file by offsets from the first symbol in
160 the table) into physical pointers to elements in the new
161 internal table. This involves some work since the meanings of
162 fields change depending upon context: a field that is a
163 pointer to another structure in the symbol table at one moment
164 may be the size in bytes of a structure at the next. Another
165 pass is made over the table. All symbols which mark file names
166 (<<C_FILE>> symbols) are modified so that the internal
167 string points to the value in the auxent (the real filename)
168 rather than the normal text associated with the symbol
169 (@code{".file"}).
170
171 At this time the symbol names are moved around. Coff stores
172 all symbols less than nine characters long physically
173 within the symbol table; longer strings are kept at the end of
174 the file in the string table. This pass moves all strings
175 into memory and replaces them with pointers to the strings.
176
252b5132
RH
177 The symbol table is massaged once again, this time to create
178 the canonical table used by the BFD application. Each symbol
179 is inspected in turn, and a decision made (using the
180 @code{sclass} field) about the various flags to set in the
181 @code{asymbol}. @xref{Symbols}. The generated canonical table
182 shares strings with the hidden internal symbol table.
183
184 Any linenumbers are read from the coff file too, and attached
185 to the symbols which own the functions the linenumbers belong to.
186
187SUBSUBSECTION
188 Symbol writing
189
190 Writing a symbol to a coff file which didn't come from a coff
191 file will lose any debugging information. The @code{asymbol}
192 structure remembers the BFD from which the symbol was taken, and on
193 output the back end makes sure that the same destination target as
194 source target is present.
195
196 When the symbols have come from a coff file then all the
197 debugging information is preserved.
198
199 Symbol tables are provided for writing to the back end in a
200 vector of pointers to pointers. This allows applications like
201 the linker to accumulate and output large symbol tables
202 without having to do too much byte copying.
203
204 This function runs through the provided symbol table and
205 patches each symbol marked as a file place holder
206 (@code{C_FILE}) to point to the next file place holder in the
207 list. It also marks each @code{offset} field in the list with
208 the offset from the first symbol of the current symbol.
209
210 Another function of this procedure is to turn the canonical
211 value form of BFD into the form used by coff. Internally, BFD
212 expects symbol values to be offsets from a section base; so a
213 symbol physically at 0x120, but in a section starting at
214 0x100, would have the value 0x20. Coff expects symbols to
215 contain their final value, so symbols have their values
216 changed at this point to reflect their sum with their owning
217 section. This transformation uses the
218 <<output_section>> field of the @code{asymbol}'s
219 @code{asection} @xref{Sections}.
220
221 o <<coff_mangle_symbols>>
222
223 This routine runs though the provided symbol table and uses
224 the offsets generated by the previous pass and the pointers
225 generated when the symbol table was read in to create the
ed781d5d 226 structured hierarchy required by coff. It changes each pointer
252b5132
RH
227 to a symbol into the index into the symbol table of the asymbol.
228
229 o <<coff_write_symbols>>
230
231 This routine runs through the symbol table and patches up the
232 symbols from their internal form into the coff way, calls the
233 bit twiddlers, and writes out the table to the file.
234
235*/
236
237/*
238INTERNAL_DEFINITION
239 coff_symbol_type
240
241DESCRIPTION
242 The hidden information for an <<asymbol>> is described in a
243 <<combined_entry_type>>:
244
245CODE_FRAGMENT
246.
247.typedef struct coff_ptr_struct
248.{
dc810e39
AM
249. {* Remembers the offset from the first symbol in the file for
250. this symbol. Generated by coff_renumber_symbols. *}
251. unsigned int offset;
252b5132 252.
dc810e39
AM
253. {* Should the value of this symbol be renumbered. Used for
254. XCOFF C_BSTAT symbols. Set by coff_slurp_symbol_table. *}
255. unsigned int fix_value : 1;
252b5132 256.
dc810e39
AM
257. {* Should the tag field of this symbol be renumbered.
258. Created by coff_pointerize_aux. *}
259. unsigned int fix_tag : 1;
252b5132 260.
dc810e39
AM
261. {* Should the endidx field of this symbol be renumbered.
262. Created by coff_pointerize_aux. *}
263. unsigned int fix_end : 1;
252b5132 264.
dc810e39
AM
265. {* Should the x_csect.x_scnlen field be renumbered.
266. Created by coff_pointerize_aux. *}
267. unsigned int fix_scnlen : 1;
252b5132 268.
dc810e39
AM
269. {* Fix up an XCOFF C_BINCL/C_EINCL symbol. The value is the
270. index into the line number entries. Set by coff_slurp_symbol_table. *}
271. unsigned int fix_line : 1;
252b5132 272.
dc810e39
AM
273. {* The container for the symbol structure as read and translated
274. from the file. *}
275. union
276. {
277. union internal_auxent auxent;
278. struct internal_syment syment;
279. } u;
252b5132
RH
280.} combined_entry_type;
281.
282.
283.{* Each canonical asymbol really looks like this: *}
284.
285.typedef struct coff_symbol_struct
286.{
dc810e39
AM
287. {* The actual symbol which the rest of BFD works with *}
288. asymbol symbol;
252b5132 289.
dc810e39
AM
290. {* A pointer to the hidden information for this symbol *}
291. combined_entry_type *native;
252b5132 292.
dc810e39
AM
293. {* A pointer to the linenumber information for this symbol *}
294. struct lineno_cache_entry *lineno;
252b5132 295.
dc810e39 296. {* Have the line numbers been relocated yet ? *}
b34976b6 297. bfd_boolean done_lineno;
252b5132
RH
298.} coff_symbol_type;
299
252b5132
RH
300*/
301
302#ifdef COFF_WITH_PE
303#include "peicode.h"
304#else
305#include "coffswap.h"
306#endif
307
b5b2699c 308#define STRING_SIZE_SIZE 4
252b5132 309
8a7140c3
NC
310#define DOT_DEBUG ".debug"
311#define GNU_LINKONCE_WI ".gnu.linkonce.wi."
312
b34976b6 313static long sec_to_styp_flags
7920ce38 314 (const char *, flagword);
b34976b6 315static bfd_boolean styp_to_sec_flags
7920ce38 316 (bfd *, void *, const char *, asection *, flagword *);
b34976b6 317static bfd_boolean coff_bad_format_hook
7920ce38 318 (bfd *, void *);
5dccc1dd 319static void coff_set_custom_section_alignment
7920ce38
NC
320 (bfd *, asection *, const struct coff_section_alignment_entry *,
321 const unsigned int);
b34976b6 322static bfd_boolean coff_new_section_hook
7920ce38 323 (bfd *, asection *);
b34976b6 324static bfd_boolean coff_set_arch_mach_hook
7920ce38 325 (bfd *, void *);
b34976b6 326static bfd_boolean coff_write_relocs
7920ce38 327 (bfd *, int);
b34976b6 328static bfd_boolean coff_set_flags
7920ce38 329 (bfd *, unsigned int *, unsigned short *);
b34976b6 330static bfd_boolean coff_set_arch_mach
7920ce38 331 (bfd *, enum bfd_architecture, unsigned long) ATTRIBUTE_UNUSED;
b34976b6 332static bfd_boolean coff_compute_section_file_positions
7920ce38 333 (bfd *);
b34976b6 334static bfd_boolean coff_write_object_contents
7920ce38 335 (bfd *) ATTRIBUTE_UNUSED;
b34976b6 336static bfd_boolean coff_set_section_contents
7920ce38
NC
337 (bfd *, asection *, const void *, file_ptr, bfd_size_type);
338static void * buy_and_read
339 (bfd *, file_ptr, bfd_size_type);
b34976b6 340static bfd_boolean coff_slurp_line_table
7920ce38 341 (bfd *, asection *);
b34976b6 342static bfd_boolean coff_slurp_symbol_table
7920ce38 343 (bfd *);
5d54c628 344static enum coff_symbol_classification coff_classify_symbol
7920ce38 345 (bfd *, struct internal_syment *);
b34976b6 346static bfd_boolean coff_slurp_reloc_table
7920ce38 347 (bfd *, asection *, asymbol **);
252b5132 348static long coff_canonicalize_reloc
7920ce38 349 (bfd *, asection *, arelent **, asymbol **);
252b5132 350#ifndef coff_mkobject_hook
7920ce38
NC
351static void * coff_mkobject_hook
352 (bfd *, void *, void *);
252b5132 353#endif
1276aefa 354#ifdef COFF_WITH_PE
b34976b6 355static flagword handle_COMDAT
7920ce38 356 (bfd *, flagword, void *, const char *, asection *);
1276aefa 357#endif
05793179 358#ifdef COFF_IMAGE_WITH_PE
b34976b6 359static bfd_boolean coff_read_word
7920ce38 360 (bfd *, unsigned int *);
b34976b6 361static unsigned int coff_compute_checksum
7920ce38 362 (bfd *);
b34976b6 363static bfd_boolean coff_apply_checksum
7920ce38 364 (bfd *);
05793179 365#endif
5a5b9651
SS
366#ifdef TICOFF
367static bfd_boolean ticoff0_bad_format_hook
7920ce38 368 (bfd *, void * );
5a5b9651 369static bfd_boolean ticoff1_bad_format_hook
7920ce38 370 (bfd *, void * );
5a5b9651 371#endif
252b5132
RH
372\f
373/* void warning(); */
374
41733515
ILT
375/* Return a word with STYP_* (scnhdr.s_flags) flags set to represent
376 the incoming SEC_* flags. The inverse of this function is
377 styp_to_sec_flags(). NOTE: If you add to/change this routine, you
378 should probably mirror the changes in styp_to_sec_flags(). */
379
380#ifndef COFF_WITH_PE
381
51db3708 382/* Macros for setting debugging flags. */
7920ce38 383
51db3708
NC
384#ifdef STYP_DEBUG
385#define STYP_XCOFF_DEBUG STYP_DEBUG
386#else
387#define STYP_XCOFF_DEBUG STYP_INFO
388#endif
389
390#ifdef COFF_ALIGN_IN_S_FLAGS
391#define STYP_DEBUG_INFO STYP_DSECT
392#else
393#define STYP_DEBUG_INFO STYP_INFO
394#endif
395
252b5132 396static long
7920ce38 397sec_to_styp_flags (const char *sec_name, flagword sec_flags)
252b5132
RH
398{
399 long styp_flags = 0;
400
401 if (!strcmp (sec_name, _TEXT))
402 {
403 styp_flags = STYP_TEXT;
404 }
405 else if (!strcmp (sec_name, _DATA))
406 {
407 styp_flags = STYP_DATA;
408 }
409 else if (!strcmp (sec_name, _BSS))
410 {
411 styp_flags = STYP_BSS;
412#ifdef _COMMENT
413 }
414 else if (!strcmp (sec_name, _COMMENT))
415 {
416 styp_flags = STYP_INFO;
417#endif /* _COMMENT */
418#ifdef _LIB
419 }
420 else if (!strcmp (sec_name, _LIB))
421 {
422 styp_flags = STYP_LIB;
423#endif /* _LIB */
424#ifdef _LIT
425 }
426 else if (!strcmp (sec_name, _LIT))
427 {
428 styp_flags = STYP_LIT;
429#endif /* _LIT */
430 }
0112cd26 431 else if (CONST_STRNEQ (sec_name, DOT_DEBUG))
252b5132 432 {
51db3708
NC
433 /* Handle the XCOFF debug section and DWARF2 debug sections. */
434 if (!sec_name[6])
435 styp_flags = STYP_XCOFF_DEBUG;
436 else
437 styp_flags = STYP_DEBUG_INFO;
252b5132 438 }
0112cd26 439 else if (CONST_STRNEQ (sec_name, ".stab"))
252b5132 440 {
51db3708
NC
441 styp_flags = STYP_DEBUG_INFO;
442 }
443#ifdef COFF_LONG_SECTION_NAMES
0112cd26 444 else if (CONST_STRNEQ (sec_name, GNU_LINKONCE_WI))
51db3708
NC
445 {
446 styp_flags = STYP_DEBUG_INFO;
252b5132 447 }
51db3708 448#endif
252b5132
RH
449#ifdef RS6000COFF_C
450 else if (!strcmp (sec_name, _PAD))
451 {
452 styp_flags = STYP_PAD;
453 }
454 else if (!strcmp (sec_name, _LOADER))
455 {
456 styp_flags = STYP_LOADER;
457 }
67fdeebe
TR
458 else if (!strcmp (sec_name, _EXCEPT))
459 {
460 styp_flags = STYP_EXCEPT;
461 }
462 else if (!strcmp (sec_name, _TYPCHK))
463 {
464 styp_flags = STYP_TYPCHK;
465 }
252b5132
RH
466#endif
467 /* Try and figure out what it should be */
468 else if (sec_flags & SEC_CODE)
469 {
470 styp_flags = STYP_TEXT;
471 }
472 else if (sec_flags & SEC_DATA)
473 {
474 styp_flags = STYP_DATA;
475 }
476 else if (sec_flags & SEC_READONLY)
477 {
478#ifdef STYP_LIT /* 29k readonly text/data section */
479 styp_flags = STYP_LIT;
480#else
481 styp_flags = STYP_TEXT;
482#endif /* STYP_LIT */
483 }
484 else if (sec_flags & SEC_LOAD)
485 {
486 styp_flags = STYP_TEXT;
487 }
488 else if (sec_flags & SEC_ALLOC)
489 {
490 styp_flags = STYP_BSS;
491 }
492
34cbe64e 493#ifdef STYP_CLINK
ebe372c1 494 if (sec_flags & SEC_TIC54X_CLINK)
34cbe64e
TW
495 styp_flags |= STYP_CLINK;
496#endif
497
498#ifdef STYP_BLOCK
ebe372c1 499 if (sec_flags & SEC_TIC54X_BLOCK)
34cbe64e
TW
500 styp_flags |= STYP_BLOCK;
501#endif
502
252b5132
RH
503#ifdef STYP_NOLOAD
504 if ((sec_flags & (SEC_NEVER_LOAD | SEC_COFF_SHARED_LIBRARY)) != 0)
505 styp_flags |= STYP_NOLOAD;
506#endif
507
41733515
ILT
508 return styp_flags;
509}
510
511#else /* COFF_WITH_PE */
512
513/* The PE version; see above for the general comments. The non-PE
514 case seems to be more guessing, and breaks PE format; specifically,
515 .rdata is readonly, but it sure ain't text. Really, all this
516 should be set up properly in gas (or whatever assembler is in use),
517 and honor whatever objcopy/strip, etc. sent us as input. */
518
519static long
7920ce38 520sec_to_styp_flags (const char *sec_name, flagword sec_flags)
41733515
ILT
521{
522 long styp_flags = 0;
523
524 /* caution: there are at least three groups of symbols that have
525 very similar bits and meanings: IMAGE_SCN*, SEC_*, and STYP_*.
526 SEC_* are the BFD internal flags, used for generic BFD
527 information. STYP_* are the COFF section flags which appear in
528 COFF files. IMAGE_SCN_* are the PE section flags which appear in
529 PE files. The STYP_* flags and the IMAGE_SCN_* flags overlap,
530 but there are more IMAGE_SCN_* flags. */
531
8a7140c3 532 /* FIXME: There is no gas syntax to specify the debug section flag. */
0112cd26
NC
533 if (CONST_STRNEQ (sec_name, DOT_DEBUG)
534 || CONST_STRNEQ (sec_name, GNU_LINKONCE_WI))
3b137b9a 535 sec_flags = SEC_DEBUGGING;
8a7140c3 536
41733515
ILT
537 /* skip LOAD */
538 /* READONLY later */
539 /* skip RELOC */
540 if ((sec_flags & SEC_CODE) != 0)
541 styp_flags |= IMAGE_SCN_CNT_CODE;
542 if ((sec_flags & SEC_DATA) != 0)
543 styp_flags |= IMAGE_SCN_CNT_INITIALIZED_DATA;
544 if ((sec_flags & SEC_ALLOC) != 0 && (sec_flags & SEC_LOAD) == 0)
545 styp_flags |= IMAGE_SCN_CNT_UNINITIALIZED_DATA; /* ==STYP_BSS */
546 /* skip ROM */
dc810e39 547 /* skip constRUCTOR */
41733515 548 /* skip CONTENTS */
41733515 549 if ((sec_flags & SEC_IS_COMMON) != 0)
252b5132 550 styp_flags |= IMAGE_SCN_LNK_COMDAT;
41733515
ILT
551 if ((sec_flags & SEC_DEBUGGING) != 0)
552 styp_flags |= IMAGE_SCN_MEM_DISCARDABLE;
553 if ((sec_flags & SEC_EXCLUDE) != 0)
554 styp_flags |= IMAGE_SCN_LNK_REMOVE;
555 if ((sec_flags & SEC_NEVER_LOAD) != 0)
556 styp_flags |= IMAGE_SCN_LNK_REMOVE;
557 /* skip IN_MEMORY */
558 /* skip SORT */
e60b52c6
KH
559 if (sec_flags & SEC_LINK_ONCE)
560 styp_flags |= IMAGE_SCN_LNK_COMDAT;
41733515
ILT
561 /* skip LINK_DUPLICATES */
562 /* skip LINKER_CREATED */
563
2ae0844c 564 if (sec_flags & (SEC_ALLOC | SEC_LOAD))
3b137b9a
CF
565 {
566 /* For now, the read/write bits are mapped onto SEC_READONLY, even
567 though the semantics don't quite match. The bits from the input
568 are retained in pei_section_data(abfd, section)->pe_flags. */
569 styp_flags |= IMAGE_SCN_MEM_READ; /* Always readable. */
570 if ((sec_flags & SEC_READONLY) == 0)
571 styp_flags |= IMAGE_SCN_MEM_WRITE; /* Invert READONLY for write. */
572 if (sec_flags & SEC_CODE)
573 styp_flags |= IMAGE_SCN_MEM_EXECUTE; /* CODE->EXECUTE. */
574 if (sec_flags & SEC_COFF_SHARED)
575 styp_flags |= IMAGE_SCN_MEM_SHARED; /* Shared remains meaningful. */
576 }
252b5132 577
e60b52c6 578 return styp_flags;
252b5132 579}
41733515
ILT
580
581#endif /* COFF_WITH_PE */
582
583/* Return a word with SEC_* flags set to represent the incoming STYP_*
584 flags (from scnhdr.s_flags). The inverse of this function is
585 sec_to_styp_flags(). NOTE: If you add to/change this routine, you
586 should probably mirror the changes in sec_to_styp_flags(). */
587
588#ifndef COFF_WITH_PE
589
b34976b6 590static bfd_boolean
7920ce38
NC
591styp_to_sec_flags (bfd *abfd ATTRIBUTE_UNUSED,
592 void * hdr,
593 const char *name,
594 asection *section ATTRIBUTE_UNUSED,
595 flagword *flags_ptr)
252b5132
RH
596{
597 struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
598 long styp_flags = internal_s->s_flags;
599 flagword sec_flags = 0;
600
34cbe64e
TW
601#ifdef STYP_BLOCK
602 if (styp_flags & STYP_BLOCK)
ebe372c1 603 sec_flags |= SEC_TIC54X_BLOCK;
e60b52c6 604#endif
34cbe64e
TW
605
606#ifdef STYP_CLINK
607 if (styp_flags & STYP_CLINK)
ebe372c1 608 sec_flags |= SEC_TIC54X_CLINK;
e60b52c6 609#endif
34cbe64e 610
252b5132
RH
611#ifdef STYP_NOLOAD
612 if (styp_flags & STYP_NOLOAD)
7c8ca0e4 613 sec_flags |= SEC_NEVER_LOAD;
252b5132
RH
614#endif /* STYP_NOLOAD */
615
616 /* For 386 COFF, at least, an unloadable text or data section is
617 actually a shared library section. */
618 if (styp_flags & STYP_TEXT)
619 {
620 if (sec_flags & SEC_NEVER_LOAD)
621 sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
622 else
623 sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
624 }
625 else if (styp_flags & STYP_DATA)
626 {
627 if (sec_flags & SEC_NEVER_LOAD)
628 sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
629 else
630 sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
631 }
632 else if (styp_flags & STYP_BSS)
633 {
634#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
635 if (sec_flags & SEC_NEVER_LOAD)
636 sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
637 else
638#endif
639 sec_flags |= SEC_ALLOC;
640 }
641 else if (styp_flags & STYP_INFO)
642 {
643 /* We mark these as SEC_DEBUGGING, but only if COFF_PAGE_SIZE is
644 defined. coff_compute_section_file_positions uses
645 COFF_PAGE_SIZE to ensure that the low order bits of the
646 section VMA and the file offset match. If we don't know
647 COFF_PAGE_SIZE, we can't ensure the correct correspondence,
648 and demand page loading of the file will fail. */
649#if defined (COFF_PAGE_SIZE) && !defined (COFF_ALIGN_IN_S_FLAGS)
650 sec_flags |= SEC_DEBUGGING;
651#endif
652 }
653 else if (styp_flags & STYP_PAD)
7c8ca0e4 654 sec_flags = 0;
252b5132
RH
655 else if (strcmp (name, _TEXT) == 0)
656 {
657 if (sec_flags & SEC_NEVER_LOAD)
658 sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
659 else
660 sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
661 }
662 else if (strcmp (name, _DATA) == 0)
663 {
664 if (sec_flags & SEC_NEVER_LOAD)
665 sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
666 else
667 sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
668 }
669 else if (strcmp (name, _BSS) == 0)
670 {
671#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
672 if (sec_flags & SEC_NEVER_LOAD)
673 sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
674 else
675#endif
676 sec_flags |= SEC_ALLOC;
677 }
0112cd26 678 else if (CONST_STRNEQ (name, DOT_DEBUG)
252b5132
RH
679#ifdef _COMMENT
680 || strcmp (name, _COMMENT) == 0
51db3708
NC
681#endif
682#ifdef COFF_LONG_SECTION_NAMES
0112cd26 683 || CONST_STRNEQ (name, GNU_LINKONCE_WI)
252b5132 684#endif
0112cd26 685 || CONST_STRNEQ (name, ".stab"))
252b5132
RH
686 {
687#ifdef COFF_PAGE_SIZE
688 sec_flags |= SEC_DEBUGGING;
689#endif
690 }
691#ifdef _LIB
692 else if (strcmp (name, _LIB) == 0)
693 ;
694#endif
695#ifdef _LIT
696 else if (strcmp (name, _LIT) == 0)
7c8ca0e4 697 sec_flags = SEC_LOAD | SEC_ALLOC | SEC_READONLY;
252b5132
RH
698#endif
699 else
7c8ca0e4 700 sec_flags |= SEC_ALLOC | SEC_LOAD;
252b5132 701
ed781d5d 702#ifdef STYP_LIT /* A29k readonly text/data section type. */
252b5132 703 if ((styp_flags & STYP_LIT) == STYP_LIT)
7c8ca0e4 704 sec_flags = (SEC_LOAD | SEC_ALLOC | SEC_READONLY);
252b5132 705#endif /* STYP_LIT */
7c8ca0e4 706
ed781d5d 707#ifdef STYP_OTHER_LOAD /* Other loaded sections. */
252b5132 708 if (styp_flags & STYP_OTHER_LOAD)
7c8ca0e4 709 sec_flags = (SEC_LOAD | SEC_ALLOC);
252b5132
RH
710#endif /* STYP_SDATA */
711
41733515
ILT
712#if defined (COFF_LONG_SECTION_NAMES) && defined (COFF_SUPPORT_GNU_LINKONCE)
713 /* As a GNU extension, if the name begins with .gnu.linkonce, we
714 only link a single copy of the section. This is used to support
715 g++. g++ will emit each template expansion in its own section.
716 The symbols will be defined as weak, so that multiple definitions
717 are permitted. The GNU linker extension is to actually discard
718 all but one of the sections. */
0112cd26 719 if (CONST_STRNEQ (name, ".gnu.linkonce"))
41733515
ILT
720 sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
721#endif
722
7c8ca0e4 723 if (flags_ptr == NULL)
b34976b6 724 return FALSE;
7c8ca0e4
NC
725
726 * flags_ptr = sec_flags;
b34976b6 727 return TRUE;
41733515
ILT
728}
729
730#else /* COFF_WITH_PE */
731
41733515 732static flagword
7920ce38
NC
733handle_COMDAT (bfd * abfd,
734 flagword sec_flags,
735 void * hdr,
736 const char *name,
737 asection *section)
41733515
ILT
738{
739 struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1276aefa
NC
740 bfd_byte *esymstart, *esym, *esymend;
741 int seen_state = 0;
742 char *target_name = NULL;
743
744 sec_flags |= SEC_LINK_ONCE;
745
746 /* Unfortunately, the PE format stores essential information in
747 the symbol table, of all places. We need to extract that
748 information now, so that objdump and the linker will know how
749 to handle the section without worrying about the symbols. We
750 can't call slurp_symtab, because the linker doesn't want the
751 swapped symbols. */
752
753 /* COMDAT sections are special. The first symbol is the section
754 symbol, which tells what kind of COMDAT section it is. The
755 second symbol is the "comdat symbol" - the one with the
756 unique name. GNU uses the section symbol for the unique
757 name; MS uses ".text" for every comdat section. Sigh. - DJ */
758
759 /* This is not mirrored in sec_to_styp_flags(), but there
760 doesn't seem to be a need to, either, and it would at best be
761 rather messy. */
762
763 if (! _bfd_coff_get_external_symbols (abfd))
764 return sec_flags;
dc810e39 765
1276aefa
NC
766 esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
767 esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
768
769 while (esym < esymend)
41733515 770 {
1276aefa
NC
771 struct internal_syment isym;
772 char buf[SYMNMLEN + 1];
773 const char *symname;
252b5132 774
7920ce38 775 bfd_coff_swap_sym_in (abfd, esym, & isym);
252b5132 776
1276aefa
NC
777 if (sizeof (internal_s->s_name) > SYMNMLEN)
778 {
779 /* This case implies that the matching
780 symbol name will be in the string table. */
781 abort ();
782 }
783
784 if (isym.n_scnum == section->target_index)
785 {
786 /* According to the MSVC documentation, the first
787 TWO entries with the section # are both of
788 interest to us. The first one is the "section
789 symbol" (section name). The second is the comdat
790 symbol name. Here, we've found the first
791 qualifying entry; we distinguish it from the
792 second with a state flag.
793
794 In the case of gas-generated (at least until that
795 is fixed) .o files, it isn't necessarily the
796 second one. It may be some other later symbol.
797
798 Since gas also doesn't follow MS conventions and
799 emits the section similar to .text$<name>, where
800 <something> is the name we're looking for, we
801 distinguish the two as follows:
802
803 If the section name is simply a section name (no
804 $) we presume it's MS-generated, and look at
805 precisely the second symbol for the comdat name.
806 If the section name has a $, we assume it's
807 gas-generated, and look for <something> (whatever
808 follows the $) as the comdat symbol. */
809
ed781d5d 810 /* All 3 branches use this. */
1276aefa
NC
811 symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
812
813 if (symname == NULL)
814 abort ();
815
816 switch (seen_state)
252b5132 817 {
1276aefa
NC
818 case 0:
819 {
820 /* The first time we've seen the symbol. */
821 union internal_auxent aux;
822
1276aefa
NC
823 /* If it isn't the stuff we're expecting, die;
824 The MS documentation is vague, but it
825 appears that the second entry serves BOTH
826 as the comdat symbol and the defining
827 symbol record (either C_STAT or C_EXT,
828 possibly with an aux entry with debug
829 information if it's a function.) It
830 appears the only way to find the second one
831 is to count. (On Intel, they appear to be
832 adjacent, but on Alpha, they have been
833 found separated.)
834
835 Here, we think we've found the first one,
836 but there's some checking we can do to be
837 sure. */
838
839 if (! (isym.n_sclass == C_STAT
840 && isym.n_type == T_NULL
841 && isym.n_value == 0))
842 abort ();
252b5132 843
1276aefa
NC
844 /* FIXME LATER: MSVC generates section names
845 like .text for comdats. Gas generates
846 names like .text$foo__Fv (in the case of a
847 function). See comment above for more. */
252b5132 848
1276aefa 849 if (strcmp (name, symname) != 0)
6e3b6835
NC
850 _bfd_error_handler (_("%B: warning: COMDAT symbol '%s' does not match section name '%s'"),
851 abfd, symname, name);
852
853 seen_state = 1;
252b5132 854
1276aefa 855 /* This is the section symbol. */
7920ce38 856 bfd_coff_swap_aux_in (abfd, (esym + bfd_coff_symesz (abfd)),
1276aefa 857 isym.n_type, isym.n_sclass,
7920ce38 858 0, isym.n_numaux, & aux);
1276aefa
NC
859
860 target_name = strchr (name, '$');
861 if (target_name != NULL)
862 {
863 /* Gas mode. */
864 seen_state = 2;
865 /* Skip the `$'. */
866 target_name += 1;
867 }
868
869 /* FIXME: Microsoft uses NODUPLICATES and
870 ASSOCIATIVE, but gnu uses ANY and
871 SAME_SIZE. Unfortunately, gnu doesn't do
872 the comdat symbols right. So, until we can
873 fix it to do the right thing, we are
874 temporarily disabling comdats for the MS
875 types (they're used in DLLs and C++, but we
876 don't support *their* C++ libraries anyway
877 - DJ. */
878
879 /* Cygwin does not follow the MS style, and
880 uses ANY and SAME_SIZE where NODUPLICATES
881 and ASSOCIATIVE should be used. For
882 Interix, we just do the right thing up
883 front. */
884
885 switch (aux.x_scn.x_comdat)
886 {
887 case IMAGE_COMDAT_SELECT_NODUPLICATES:
e60b52c6 888#ifdef STRICT_PE_FORMAT
1276aefa 889 sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
ec0ef80e 890#else
1276aefa 891 sec_flags &= ~SEC_LINK_ONCE;
ec0ef80e 892#endif
1276aefa 893 break;
252b5132 894
1276aefa
NC
895 case IMAGE_COMDAT_SELECT_ANY:
896 sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
897 break;
252b5132 898
1276aefa
NC
899 case IMAGE_COMDAT_SELECT_SAME_SIZE:
900 sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
901 break;
252b5132 902
1276aefa
NC
903 case IMAGE_COMDAT_SELECT_EXACT_MATCH:
904 /* Not yet fully implemented ??? */
905 sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
906 break;
252b5132 907
1276aefa
NC
908 /* debug$S gets this case; other
909 implications ??? */
e5db213d 910
1276aefa
NC
911 /* There may be no symbol... we'll search
912 the whole table... Is this the right
913 place to play this game? Or should we do
914 it when reading it in. */
915 case IMAGE_COMDAT_SELECT_ASSOCIATIVE:
0717ebb7 916#ifdef STRICT_PE_FORMAT
1276aefa
NC
917 /* FIXME: This is not currently implemented. */
918 sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
ec0ef80e 919#else
1276aefa 920 sec_flags &= ~SEC_LINK_ONCE;
ec0ef80e 921#endif
1276aefa 922 break;
e5db213d 923
1276aefa
NC
924 default: /* 0 means "no symbol" */
925 /* debug$F gets this case; other
926 implications ??? */
927 sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
928 break;
929 }
930 }
931 break;
41733515 932
1276aefa
NC
933 case 2:
934 /* Gas mode: the first matching on partial name. */
252b5132 935
e5db213d
ILT
936#ifndef TARGET_UNDERSCORE
937#define TARGET_UNDERSCORE 0
938#endif
ed781d5d 939 /* Is this the name we're looking for ? */
1276aefa
NC
940 if (strcmp (target_name,
941 symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
942 {
943 /* Not the name we're looking for */
944 esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd);
945 continue;
252b5132 946 }
1276aefa
NC
947 /* Fall through. */
948 case 1:
949 /* MSVC mode: the lexically second symbol (or
950 drop through from the above). */
951 {
952 char *newname;
dc810e39 953 bfd_size_type amt;
1276aefa 954
08da05b0 955 /* This must the second symbol with the
1276aefa
NC
956 section #. It is the actual symbol name.
957 Intel puts the two adjacent, but Alpha (at
958 least) spreads them out. */
959
082b7297
L
960 amt = sizeof (struct coff_comdat_info);
961 coff_section_data (abfd, section)->comdat
962 = bfd_alloc (abfd, amt);
963 if (coff_section_data (abfd, section)->comdat == NULL)
1276aefa
NC
964 abort ();
965
082b7297 966 coff_section_data (abfd, section)->comdat->symbol =
1276aefa
NC
967 (esym - esymstart) / bfd_coff_symesz (abfd);
968
dc810e39
AM
969 amt = strlen (symname) + 1;
970 newname = bfd_alloc (abfd, amt);
1276aefa
NC
971 if (newname == NULL)
972 abort ();
973
974 strcpy (newname, symname);
082b7297
L
975 coff_section_data (abfd, section)->comdat->name
976 = newname;
1276aefa 977 }
252b5132 978
1276aefa 979 goto breakloop;
252b5132
RH
980 }
981 }
1276aefa
NC
982
983 esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd);
984 }
985
986 breakloop:
987 return sec_flags;
988}
989
990
991/* The PE version; see above for the general comments.
992
993 Since to set the SEC_LINK_ONCE and associated flags, we have to
994 look at the symbol table anyway, we return the symbol table index
995 of the symbol being used as the COMDAT symbol. This is admittedly
996 ugly, but there's really nowhere else that we have access to the
997 required information. FIXME: Is the COMDAT symbol index used for
998 any purpose other than objdump? */
999
b34976b6 1000static bfd_boolean
7920ce38
NC
1001styp_to_sec_flags (bfd *abfd,
1002 void * hdr,
1003 const char *name,
1004 asection *section,
1005 flagword *flags_ptr)
1276aefa
NC
1006{
1007 struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1008 long styp_flags = internal_s->s_flags;
1009 flagword sec_flags;
b34976b6 1010 bfd_boolean result = TRUE;
1276aefa
NC
1011
1012 /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified. */
1013 sec_flags = SEC_READONLY;
1014
1015 /* Process each flag bit in styp_flags in turn. */
1016 while (styp_flags)
1017 {
1018 long flag = styp_flags & - styp_flags;
1019 char * unhandled = NULL;
dc810e39 1020
1276aefa
NC
1021 styp_flags &= ~ flag;
1022
1023 /* We infer from the distinct read/write/execute bits the settings
1024 of some of the bfd flags; the actual values, should we need them,
1025 are also in pei_section_data (abfd, section)->pe_flags. */
1026
1027 switch (flag)
1028 {
1029 case STYP_DSECT:
1030 unhandled = "STYP_DSECT";
1031 break;
1032 case STYP_GROUP:
1033 unhandled = "STYP_GROUP";
1034 break;
1035 case STYP_COPY:
1036 unhandled = "STYP_COPY";
1037 break;
1038 case STYP_OVER:
1039 unhandled = "STYP_OVER";
1040 break;
1041#ifdef SEC_NEVER_LOAD
1042 case STYP_NOLOAD:
1043 sec_flags |= SEC_NEVER_LOAD;
1044 break;
dc810e39 1045#endif
1276aefa
NC
1046 case IMAGE_SCN_MEM_READ:
1047 /* Ignored, assume it always to be true. */
1048 break;
1049 case IMAGE_SCN_TYPE_NO_PAD:
1050 /* Skip. */
1051 break;
1052 case IMAGE_SCN_LNK_OTHER:
1053 unhandled = "IMAGE_SCN_LNK_OTHER";
1054 break;
1055 case IMAGE_SCN_MEM_NOT_CACHED:
1056 unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1057 break;
1058 case IMAGE_SCN_MEM_NOT_PAGED:
05576f10
NC
1059 /* Generate a warning message rather using the 'unhandled'
1060 variable as this will allow some .sys files generate by
1061 other toolchains to be processed. See bugzilla issue 196. */
d003868e
AM
1062 _bfd_error_handler (_("%B: Warning: Ignoring section flag IMAGE_SCN_MEM_NOT_PAGED in section %s"),
1063 abfd, name);
1276aefa
NC
1064 break;
1065 case IMAGE_SCN_MEM_EXECUTE:
1066 sec_flags |= SEC_CODE;
1067 break;
1068 case IMAGE_SCN_MEM_WRITE:
1069 sec_flags &= ~ SEC_READONLY;
1070 break;
1071 case IMAGE_SCN_MEM_DISCARDABLE:
c4bf7794
NC
1072 /* The MS PE spec sets the DISCARDABLE flag on .reloc sections
1073 but we do not want them to be labelled as debug section, since
1074 then strip would remove them. */
0112cd26 1075 if (! CONST_STRNEQ (name, ".reloc"))
c4bf7794 1076 sec_flags |= SEC_DEBUGGING;
1276aefa
NC
1077 break;
1078 case IMAGE_SCN_MEM_SHARED:
ebe372c1 1079 sec_flags |= SEC_COFF_SHARED;
1276aefa
NC
1080 break;
1081 case IMAGE_SCN_LNK_REMOVE:
1082 sec_flags |= SEC_EXCLUDE;
1083 break;
1084 case IMAGE_SCN_CNT_CODE:
1085 sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1086 break;
1087 case IMAGE_SCN_CNT_INITIALIZED_DATA:
1088 sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1089 break;
1090 case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1091 sec_flags |= SEC_ALLOC;
1092 break;
1093 case IMAGE_SCN_LNK_INFO:
1094 /* We mark these as SEC_DEBUGGING, but only if COFF_PAGE_SIZE is
1095 defined. coff_compute_section_file_positions uses
1096 COFF_PAGE_SIZE to ensure that the low order bits of the
1097 section VMA and the file offset match. If we don't know
1098 COFF_PAGE_SIZE, we can't ensure the correct correspondence,
1099 and demand page loading of the file will fail. */
1100#ifdef COFF_PAGE_SIZE
1101 sec_flags |= SEC_DEBUGGING;
1102#endif
1103 break;
1104 case IMAGE_SCN_LNK_COMDAT:
1105 /* COMDAT gets very special treatment. */
1106 sec_flags = handle_COMDAT (abfd, sec_flags, hdr, name, section);
1107 break;
1108 default:
1109 /* Silently ignore for now. */
dc810e39 1110 break;
1276aefa
NC
1111 }
1112
7c8ca0e4 1113 /* If the section flag was not handled, report it here. */
1276aefa 1114 if (unhandled != NULL)
7c8ca0e4
NC
1115 {
1116 (*_bfd_error_handler)
d003868e
AM
1117 (_("%B (%s): Section flag %s (0x%x) ignored"),
1118 abfd, name, unhandled, flag);
b34976b6 1119 result = FALSE;
7c8ca0e4 1120 }
252b5132 1121 }
252b5132 1122
242eabea
ILT
1123#if defined (COFF_LONG_SECTION_NAMES) && defined (COFF_SUPPORT_GNU_LINKONCE)
1124 /* As a GNU extension, if the name begins with .gnu.linkonce, we
1125 only link a single copy of the section. This is used to support
1126 g++. g++ will emit each template expansion in its own section.
1127 The symbols will be defined as weak, so that multiple definitions
1128 are permitted. The GNU linker extension is to actually discard
1129 all but one of the sections. */
0112cd26 1130 if (CONST_STRNEQ (name, ".gnu.linkonce"))
242eabea
ILT
1131 sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
1132#endif
1133
7c8ca0e4
NC
1134 if (flags_ptr)
1135 * flags_ptr = sec_flags;
dc810e39 1136
7c8ca0e4 1137 return result;
252b5132
RH
1138}
1139
41733515
ILT
1140#endif /* COFF_WITH_PE */
1141
252b5132
RH
1142#define get_index(symbol) ((symbol)->udata.i)
1143
1144/*
1145INTERNAL_DEFINITION
1146 bfd_coff_backend_data
1147
1148CODE_FRAGMENT
1149
5d54c628
ILT
1150.{* COFF symbol classifications. *}
1151.
1152.enum coff_symbol_classification
1153.{
1154. {* Global symbol. *}
1155. COFF_SYMBOL_GLOBAL,
1156. {* Common symbol. *}
1157. COFF_SYMBOL_COMMON,
1158. {* Undefined symbol. *}
1159. COFF_SYMBOL_UNDEFINED,
1160. {* Local symbol. *}
1161. COFF_SYMBOL_LOCAL,
1162. {* PE section symbol. *}
1163. COFF_SYMBOL_PE_SECTION
1164.};
1165.
252b5132
RH
1166Special entry points for gdb to swap in coff symbol table parts:
1167.typedef struct
1168.{
dc810e39 1169. void (*_bfd_coff_swap_aux_in)
7920ce38 1170. (bfd *, void *, int, int, int, int, void *);
252b5132 1171.
dc810e39 1172. void (*_bfd_coff_swap_sym_in)
7920ce38 1173. (bfd *, void *, void *);
252b5132 1174.
dc810e39 1175. void (*_bfd_coff_swap_lineno_in)
7920ce38 1176. (bfd *, void *, void *);
252b5132 1177.
dc810e39 1178. unsigned int (*_bfd_coff_swap_aux_out)
7920ce38 1179. (bfd *, void *, int, int, int, int, void *);
252b5132 1180.
dc810e39 1181. unsigned int (*_bfd_coff_swap_sym_out)
7920ce38 1182. (bfd *, void *, void *);
252b5132 1183.
dc810e39 1184. unsigned int (*_bfd_coff_swap_lineno_out)
7920ce38 1185. (bfd *, void *, void *);
252b5132 1186.
dc810e39 1187. unsigned int (*_bfd_coff_swap_reloc_out)
7920ce38 1188. (bfd *, void *, void *);
252b5132 1189.
dc810e39 1190. unsigned int (*_bfd_coff_swap_filehdr_out)
7920ce38 1191. (bfd *, void *, void *);
252b5132 1192.
dc810e39 1193. unsigned int (*_bfd_coff_swap_aouthdr_out)
7920ce38 1194. (bfd *, void *, void *);
252b5132 1195.
dc810e39 1196. unsigned int (*_bfd_coff_swap_scnhdr_out)
7920ce38 1197. (bfd *, void *, void *);
252b5132 1198.
dc810e39
AM
1199. unsigned int _bfd_filhsz;
1200. unsigned int _bfd_aoutsz;
1201. unsigned int _bfd_scnhsz;
1202. unsigned int _bfd_symesz;
1203. unsigned int _bfd_auxesz;
1204. unsigned int _bfd_relsz;
1205. unsigned int _bfd_linesz;
1206. unsigned int _bfd_filnmlen;
b34976b6
AM
1207. bfd_boolean _bfd_coff_long_filenames;
1208. bfd_boolean _bfd_coff_long_section_names;
dc810e39 1209. unsigned int _bfd_coff_default_section_alignment_power;
b34976b6 1210. bfd_boolean _bfd_coff_force_symnames_in_strings;
dc810e39
AM
1211. unsigned int _bfd_coff_debug_string_prefix_length;
1212.
1213. void (*_bfd_coff_swap_filehdr_in)
7920ce38 1214. (bfd *, void *, void *);
dc810e39
AM
1215.
1216. void (*_bfd_coff_swap_aouthdr_in)
7920ce38 1217. (bfd *, void *, void *);
dc810e39
AM
1218.
1219. void (*_bfd_coff_swap_scnhdr_in)
7920ce38 1220. (bfd *, void *, void *);
dc810e39
AM
1221.
1222. void (*_bfd_coff_swap_reloc_in)
7920ce38 1223. (bfd *abfd, void *, void *);
dc810e39 1224.
b34976b6 1225. bfd_boolean (*_bfd_coff_bad_format_hook)
7920ce38 1226. (bfd *, void *);
dc810e39 1227.
b34976b6 1228. bfd_boolean (*_bfd_coff_set_arch_mach_hook)
7920ce38 1229. (bfd *, void *);
dc810e39 1230.
7920ce38
NC
1231. void * (*_bfd_coff_mkobject_hook)
1232. (bfd *, void *, void *);
dc810e39 1233.
b34976b6 1234. bfd_boolean (*_bfd_styp_to_sec_flags_hook)
7920ce38 1235. (bfd *, void *, const char *, asection *, flagword *);
dc810e39
AM
1236.
1237. void (*_bfd_set_alignment_hook)
7920ce38 1238. (bfd *, asection *, void *);
dc810e39 1239.
b34976b6 1240. bfd_boolean (*_bfd_coff_slurp_symbol_table)
7920ce38 1241. (bfd *);
dc810e39 1242.
b34976b6 1243. bfd_boolean (*_bfd_coff_symname_in_debug)
7920ce38 1244. (bfd *, struct internal_syment *);
dc810e39 1245.
b34976b6 1246. bfd_boolean (*_bfd_coff_pointerize_aux_hook)
7920ce38
NC
1247. (bfd *, combined_entry_type *, combined_entry_type *,
1248. unsigned int, combined_entry_type *);
dc810e39 1249.
b34976b6 1250. bfd_boolean (*_bfd_coff_print_aux)
7920ce38
NC
1251. (bfd *, FILE *, combined_entry_type *, combined_entry_type *,
1252. combined_entry_type *, unsigned int);
dc810e39
AM
1253.
1254. void (*_bfd_coff_reloc16_extra_cases)
7920ce38
NC
1255. (bfd *, struct bfd_link_info *, struct bfd_link_order *, arelent *,
1256. bfd_byte *, unsigned int *, unsigned int *);
dc810e39
AM
1257.
1258. int (*_bfd_coff_reloc16_estimate)
7920ce38
NC
1259. (bfd *, asection *, arelent *, unsigned int,
1260. struct bfd_link_info *);
dc810e39
AM
1261.
1262. enum coff_symbol_classification (*_bfd_coff_classify_symbol)
7920ce38 1263. (bfd *, struct internal_syment *);
dc810e39 1264.
b34976b6 1265. bfd_boolean (*_bfd_coff_compute_section_file_positions)
7920ce38 1266. (bfd *);
252b5132 1267.
b34976b6 1268. bfd_boolean (*_bfd_coff_start_final_link)
7920ce38 1269. (bfd *, struct bfd_link_info *);
dc810e39 1270.
b34976b6 1271. bfd_boolean (*_bfd_coff_relocate_section)
7920ce38
NC
1272. (bfd *, struct bfd_link_info *, bfd *, asection *, bfd_byte *,
1273. struct internal_reloc *, struct internal_syment *, asection **);
dc810e39
AM
1274.
1275. reloc_howto_type *(*_bfd_coff_rtype_to_howto)
7920ce38 1276. (bfd *, asection *, struct internal_reloc *,
dc810e39 1277. struct coff_link_hash_entry *, struct internal_syment *,
7920ce38 1278. bfd_vma *);
dc810e39 1279.
b34976b6 1280. bfd_boolean (*_bfd_coff_adjust_symndx)
7920ce38
NC
1281. (bfd *, struct bfd_link_info *, bfd *, asection *,
1282. struct internal_reloc *, bfd_boolean *);
dc810e39 1283.
b34976b6 1284. bfd_boolean (*_bfd_coff_link_add_one_symbol)
7920ce38 1285. (struct bfd_link_info *, bfd *, const char *, flagword,
b34976b6 1286. asection *, bfd_vma, const char *, bfd_boolean, bfd_boolean,
7920ce38 1287. struct bfd_link_hash_entry **);
dc810e39 1288.
b34976b6 1289. bfd_boolean (*_bfd_coff_link_output_has_begun)
7920ce38 1290. (bfd *, struct coff_final_link_info *);
dc810e39 1291.
b34976b6 1292. bfd_boolean (*_bfd_coff_final_link_postscript)
7920ce38 1293. (bfd *, struct coff_final_link_info *);
252b5132 1294.
2b5c217d
NC
1295. bfd_boolean (*_bfd_coff_print_pdata)
1296. (bfd *, void *);
1297.
252b5132
RH
1298.} bfd_coff_backend_data;
1299.
dc810e39
AM
1300.#define coff_backend_info(abfd) \
1301. ((bfd_coff_backend_data *) (abfd)->xvec->backend_data)
252b5132
RH
1302.
1303.#define bfd_coff_swap_aux_in(a,e,t,c,ind,num,i) \
dc810e39 1304. ((coff_backend_info (a)->_bfd_coff_swap_aux_in) (a,e,t,c,ind,num,i))
252b5132
RH
1305.
1306.#define bfd_coff_swap_sym_in(a,e,i) \
dc810e39 1307. ((coff_backend_info (a)->_bfd_coff_swap_sym_in) (a,e,i))
252b5132
RH
1308.
1309.#define bfd_coff_swap_lineno_in(a,e,i) \
dc810e39 1310. ((coff_backend_info ( a)->_bfd_coff_swap_lineno_in) (a,e,i))
252b5132
RH
1311.
1312.#define bfd_coff_swap_reloc_out(abfd, i, o) \
dc810e39 1313. ((coff_backend_info (abfd)->_bfd_coff_swap_reloc_out) (abfd, i, o))
252b5132
RH
1314.
1315.#define bfd_coff_swap_lineno_out(abfd, i, o) \
dc810e39 1316. ((coff_backend_info (abfd)->_bfd_coff_swap_lineno_out) (abfd, i, o))
252b5132
RH
1317.
1318.#define bfd_coff_swap_aux_out(a,i,t,c,ind,num,o) \
dc810e39 1319. ((coff_backend_info (a)->_bfd_coff_swap_aux_out) (a,i,t,c,ind,num,o))
252b5132
RH
1320.
1321.#define bfd_coff_swap_sym_out(abfd, i,o) \
dc810e39 1322. ((coff_backend_info (abfd)->_bfd_coff_swap_sym_out) (abfd, i, o))
252b5132
RH
1323.
1324.#define bfd_coff_swap_scnhdr_out(abfd, i,o) \
dc810e39 1325. ((coff_backend_info (abfd)->_bfd_coff_swap_scnhdr_out) (abfd, i, o))
252b5132
RH
1326.
1327.#define bfd_coff_swap_filehdr_out(abfd, i,o) \
dc810e39 1328. ((coff_backend_info (abfd)->_bfd_coff_swap_filehdr_out) (abfd, i, o))
252b5132
RH
1329.
1330.#define bfd_coff_swap_aouthdr_out(abfd, i,o) \
dc810e39 1331. ((coff_backend_info (abfd)->_bfd_coff_swap_aouthdr_out) (abfd, i, o))
252b5132
RH
1332.
1333.#define bfd_coff_filhsz(abfd) (coff_backend_info (abfd)->_bfd_filhsz)
1334.#define bfd_coff_aoutsz(abfd) (coff_backend_info (abfd)->_bfd_aoutsz)
1335.#define bfd_coff_scnhsz(abfd) (coff_backend_info (abfd)->_bfd_scnhsz)
1336.#define bfd_coff_symesz(abfd) (coff_backend_info (abfd)->_bfd_symesz)
1337.#define bfd_coff_auxesz(abfd) (coff_backend_info (abfd)->_bfd_auxesz)
1338.#define bfd_coff_relsz(abfd) (coff_backend_info (abfd)->_bfd_relsz)
1339.#define bfd_coff_linesz(abfd) (coff_backend_info (abfd)->_bfd_linesz)
692b7d62 1340.#define bfd_coff_filnmlen(abfd) (coff_backend_info (abfd)->_bfd_filnmlen)
dc810e39
AM
1341.#define bfd_coff_long_filenames(abfd) \
1342. (coff_backend_info (abfd)->_bfd_coff_long_filenames)
252b5132 1343.#define bfd_coff_long_section_names(abfd) \
dc810e39 1344. (coff_backend_info (abfd)->_bfd_coff_long_section_names)
252b5132 1345.#define bfd_coff_default_section_alignment_power(abfd) \
dc810e39 1346. (coff_backend_info (abfd)->_bfd_coff_default_section_alignment_power)
252b5132 1347.#define bfd_coff_swap_filehdr_in(abfd, i,o) \
dc810e39 1348. ((coff_backend_info (abfd)->_bfd_coff_swap_filehdr_in) (abfd, i, o))
252b5132
RH
1349.
1350.#define bfd_coff_swap_aouthdr_in(abfd, i,o) \
dc810e39 1351. ((coff_backend_info (abfd)->_bfd_coff_swap_aouthdr_in) (abfd, i, o))
252b5132
RH
1352.
1353.#define bfd_coff_swap_scnhdr_in(abfd, i,o) \
dc810e39 1354. ((coff_backend_info (abfd)->_bfd_coff_swap_scnhdr_in) (abfd, i, o))
252b5132
RH
1355.
1356.#define bfd_coff_swap_reloc_in(abfd, i, o) \
dc810e39 1357. ((coff_backend_info (abfd)->_bfd_coff_swap_reloc_in) (abfd, i, o))
252b5132
RH
1358.
1359.#define bfd_coff_bad_format_hook(abfd, filehdr) \
dc810e39 1360. ((coff_backend_info (abfd)->_bfd_coff_bad_format_hook) (abfd, filehdr))
252b5132
RH
1361.
1362.#define bfd_coff_set_arch_mach_hook(abfd, filehdr)\
dc810e39 1363. ((coff_backend_info (abfd)->_bfd_coff_set_arch_mach_hook) (abfd, filehdr))
252b5132 1364.#define bfd_coff_mkobject_hook(abfd, filehdr, aouthdr)\
ed781d5d
NC
1365. ((coff_backend_info (abfd)->_bfd_coff_mkobject_hook)\
1366. (abfd, filehdr, aouthdr))
252b5132 1367.
7c8ca0e4 1368.#define bfd_coff_styp_to_sec_flags_hook(abfd, scnhdr, name, section, flags_ptr)\
dc810e39
AM
1369. ((coff_backend_info (abfd)->_bfd_styp_to_sec_flags_hook)\
1370. (abfd, scnhdr, name, section, flags_ptr))
252b5132
RH
1371.
1372.#define bfd_coff_set_alignment_hook(abfd, sec, scnhdr)\
dc810e39 1373. ((coff_backend_info (abfd)->_bfd_set_alignment_hook) (abfd, sec, scnhdr))
252b5132
RH
1374.
1375.#define bfd_coff_slurp_symbol_table(abfd)\
dc810e39 1376. ((coff_backend_info (abfd)->_bfd_coff_slurp_symbol_table) (abfd))
252b5132
RH
1377.
1378.#define bfd_coff_symname_in_debug(abfd, sym)\
dc810e39 1379. ((coff_backend_info (abfd)->_bfd_coff_symname_in_debug) (abfd, sym))
252b5132 1380.
2243c419 1381.#define bfd_coff_force_symnames_in_strings(abfd)\
dc810e39 1382. (coff_backend_info (abfd)->_bfd_coff_force_symnames_in_strings)
2243c419
CP
1383.
1384.#define bfd_coff_debug_string_prefix_length(abfd)\
dc810e39 1385. (coff_backend_info (abfd)->_bfd_coff_debug_string_prefix_length)
2243c419 1386.
252b5132 1387.#define bfd_coff_print_aux(abfd, file, base, symbol, aux, indaux)\
dc810e39
AM
1388. ((coff_backend_info (abfd)->_bfd_coff_print_aux)\
1389. (abfd, file, base, symbol, aux, indaux))
252b5132 1390.
ed781d5d
NC
1391.#define bfd_coff_reloc16_extra_cases(abfd, link_info, link_order,\
1392. reloc, data, src_ptr, dst_ptr)\
dc810e39
AM
1393. ((coff_backend_info (abfd)->_bfd_coff_reloc16_extra_cases)\
1394. (abfd, link_info, link_order, reloc, data, src_ptr, dst_ptr))
252b5132
RH
1395.
1396.#define bfd_coff_reloc16_estimate(abfd, section, reloc, shrink, link_info)\
dc810e39
AM
1397. ((coff_backend_info (abfd)->_bfd_coff_reloc16_estimate)\
1398. (abfd, section, reloc, shrink, link_info))
252b5132 1399.
5d54c628 1400.#define bfd_coff_classify_symbol(abfd, sym)\
dc810e39
AM
1401. ((coff_backend_info (abfd)->_bfd_coff_classify_symbol)\
1402. (abfd, sym))
252b5132
RH
1403.
1404.#define bfd_coff_compute_section_file_positions(abfd)\
dc810e39
AM
1405. ((coff_backend_info (abfd)->_bfd_coff_compute_section_file_positions)\
1406. (abfd))
252b5132
RH
1407.
1408.#define bfd_coff_start_final_link(obfd, info)\
dc810e39
AM
1409. ((coff_backend_info (obfd)->_bfd_coff_start_final_link)\
1410. (obfd, info))
252b5132 1411.#define bfd_coff_relocate_section(obfd,info,ibfd,o,con,rel,isyms,secs)\
dc810e39
AM
1412. ((coff_backend_info (ibfd)->_bfd_coff_relocate_section)\
1413. (obfd, info, ibfd, o, con, rel, isyms, secs))
252b5132 1414.#define bfd_coff_rtype_to_howto(abfd, sec, rel, h, sym, addendp)\
dc810e39
AM
1415. ((coff_backend_info (abfd)->_bfd_coff_rtype_to_howto)\
1416. (abfd, sec, rel, h, sym, addendp))
252b5132 1417.#define bfd_coff_adjust_symndx(obfd, info, ibfd, sec, rel, adjustedp)\
dc810e39
AM
1418. ((coff_backend_info (abfd)->_bfd_coff_adjust_symndx)\
1419. (obfd, info, ibfd, sec, rel, adjustedp))
ed781d5d
NC
1420.#define bfd_coff_link_add_one_symbol(info, abfd, name, flags, section,\
1421. value, string, cp, coll, hashp)\
dc810e39
AM
1422. ((coff_backend_info (abfd)->_bfd_coff_link_add_one_symbol)\
1423. (info, abfd, name, flags, section, value, string, cp, coll, hashp))
252b5132
RH
1424.
1425.#define bfd_coff_link_output_has_begun(a,p) \
7920ce38 1426. ((coff_backend_info (a)->_bfd_coff_link_output_has_begun) (a, p))
252b5132 1427.#define bfd_coff_final_link_postscript(a,p) \
7920ce38 1428. ((coff_backend_info (a)->_bfd_coff_final_link_postscript) (a, p))
252b5132 1429.
2b5c217d
NC
1430.#define bfd_coff_have_print_pdata(a) \
1431. (coff_backend_info (a)->_bfd_coff_print_pdata)
1432.#define bfd_coff_print_pdata(a,p) \
1433. ((coff_backend_info (a)->_bfd_coff_print_pdata) (a, p))
1434.
252b5132
RH
1435*/
1436
1437/* See whether the magic number matches. */
1438
b34976b6 1439static bfd_boolean
7920ce38 1440coff_bad_format_hook (bfd * abfd ATTRIBUTE_UNUSED, void * filehdr)
252b5132
RH
1441{
1442 struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1443
1444 if (BADMAG (*internal_f))
b34976b6 1445 return FALSE;
252b5132 1446
ed781d5d 1447 /* If the optional header is NULL or not the correct size then
252b5132
RH
1448 quit; the only difference I can see between m88k dgux headers (MC88DMAGIC)
1449 and Intel 960 readwrite headers (I960WRMAGIC) is that the
1450 optional header is of a different size.
1451
1452 But the mips keeps extra stuff in it's opthdr, so dont check
ed781d5d 1453 when doing that. */
252b5132
RH
1454
1455#if defined(M88) || defined(I960)
6b3b007b 1456 if (internal_f->f_opthdr != 0 && bfd_coff_aoutsz (abfd) != internal_f->f_opthdr)
b34976b6 1457 return FALSE;
252b5132
RH
1458#endif
1459
b34976b6 1460 return TRUE;
252b5132
RH
1461}
1462
5a5b9651
SS
1463#ifdef TICOFF
1464static bfd_boolean
7920ce38 1465ticoff0_bad_format_hook (bfd *abfd ATTRIBUTE_UNUSED, void * filehdr)
5a5b9651
SS
1466{
1467 struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1468
1469 if (COFF0_BADMAG (*internal_f))
1470 return FALSE;
1471
1472 return TRUE;
1473}
1474#endif
1475
1476#ifdef TICOFF
1477static bfd_boolean
7920ce38 1478ticoff1_bad_format_hook (bfd *abfd ATTRIBUTE_UNUSED, void * filehdr)
5a5b9651
SS
1479{
1480 struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1481
1482 if (COFF1_BADMAG (*internal_f))
1483 return FALSE;
1484
1485 return TRUE;
1486}
1487#endif
1488
5dccc1dd
ILT
1489/* Check whether this section uses an alignment other than the
1490 default. */
1491
1492static void
7920ce38
NC
1493coff_set_custom_section_alignment (bfd *abfd ATTRIBUTE_UNUSED,
1494 asection *section,
1495 const struct coff_section_alignment_entry *alignment_table,
1496 const unsigned int table_size)
5dccc1dd
ILT
1497{
1498 const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1499 unsigned int i;
1500
1501 for (i = 0; i < table_size; ++i)
1502 {
1503 const char *secname = bfd_get_section_name (abfd, section);
ed781d5d 1504
5dccc1dd
ILT
1505 if (alignment_table[i].comparison_length == (unsigned int) -1
1506 ? strcmp (alignment_table[i].name, secname) == 0
1507 : strncmp (alignment_table[i].name, secname,
1508 alignment_table[i].comparison_length) == 0)
1509 break;
1510 }
1511 if (i >= table_size)
1512 return;
1513
1514 if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1515 && default_alignment < alignment_table[i].default_alignment_min)
1516 return;
1517
1518 if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1e738b87
NC
1519#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1520 && default_alignment > alignment_table[i].default_alignment_max
1521#endif
1522 )
5dccc1dd
ILT
1523 return;
1524
1525 section->alignment_power = alignment_table[i].alignment_power;
1526}
1527
1528/* Custom section alignment records. */
1529
1530static const struct coff_section_alignment_entry
1531coff_section_alignment_table[] =
1532{
1533#ifdef COFF_SECTION_ALIGNMENT_ENTRIES
1534 COFF_SECTION_ALIGNMENT_ENTRIES,
1535#endif
1536 /* There must not be any gaps between .stabstr sections. */
1537 { COFF_SECTION_NAME_PARTIAL_MATCH (".stabstr"),
1538 1, COFF_ALIGNMENT_FIELD_EMPTY, 0 },
1539 /* The .stab section must be aligned to 2**2 at most, to avoid gaps. */
1540 { COFF_SECTION_NAME_PARTIAL_MATCH (".stab"),
1541 3, COFF_ALIGNMENT_FIELD_EMPTY, 2 },
1542 /* Similarly for the .ctors and .dtors sections. */
1543 { COFF_SECTION_NAME_EXACT_MATCH (".ctors"),
1544 3, COFF_ALIGNMENT_FIELD_EMPTY, 2 },
1545 { COFF_SECTION_NAME_EXACT_MATCH (".dtors"),
1546 3, COFF_ALIGNMENT_FIELD_EMPTY, 2 }
1547};
1548
1549static const unsigned int coff_section_alignment_table_size =
1550 sizeof coff_section_alignment_table / sizeof coff_section_alignment_table[0];
1551
1552/* Initialize a section structure with information peculiar to this
1553 particular implementation of COFF. */
252b5132 1554
b34976b6 1555static bfd_boolean
7920ce38 1556coff_new_section_hook (bfd * abfd, asection * section)
252b5132
RH
1557{
1558 combined_entry_type *native;
dc810e39 1559 bfd_size_type amt;
252b5132
RH
1560
1561 section->alignment_power = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1562
1563#ifdef RS6000COFF_C
eb1e0e80 1564 if (bfd_xcoff_text_align_power (abfd) != 0
252b5132 1565 && strcmp (bfd_get_section_name (abfd, section), ".text") == 0)
eb1e0e80
NC
1566 section->alignment_power = bfd_xcoff_text_align_power (abfd);
1567 if (bfd_xcoff_data_align_power (abfd) != 0
252b5132 1568 && strcmp (bfd_get_section_name (abfd, section), ".data") == 0)
eb1e0e80 1569 section->alignment_power = bfd_xcoff_data_align_power (abfd);
252b5132
RH
1570#endif
1571
f592407e
AM
1572 /* Set up the section symbol. */
1573 if (!_bfd_generic_new_section_hook (abfd, section))
1574 return FALSE;
1575
252b5132
RH
1576 /* Allocate aux records for section symbols, to store size and
1577 related info.
1578
1579 @@ The 10 is a guess at a plausible maximum number of aux entries
1580 (but shouldn't be a constant). */
dc810e39 1581 amt = sizeof (combined_entry_type) * 10;
7920ce38 1582 native = bfd_zalloc (abfd, amt);
252b5132 1583 if (native == NULL)
b34976b6 1584 return FALSE;
252b5132
RH
1585
1586 /* We don't need to set up n_name, n_value, or n_scnum in the native
5c4491d3 1587 symbol information, since they'll be overridden by the BFD symbol
252b5132
RH
1588 anyhow. However, we do need to set the type and storage class,
1589 in case this symbol winds up getting written out. The value 0
1590 for n_numaux is already correct. */
1591
1592 native->u.syment.n_type = T_NULL;
1593 native->u.syment.n_sclass = C_STAT;
1594
1595 coffsymbol (section->symbol)->native = native;
1596
5dccc1dd
ILT
1597 coff_set_custom_section_alignment (abfd, section,
1598 coff_section_alignment_table,
1599 coff_section_alignment_table_size);
252b5132 1600
b34976b6 1601 return TRUE;
252b5132
RH
1602}
1603
1604#ifdef COFF_ALIGN_IN_SECTION_HEADER
1605
1606/* Set the alignment of a BFD section. */
1607
252b5132 1608static void
7920ce38
NC
1609coff_set_alignment_hook (bfd * abfd ATTRIBUTE_UNUSED,
1610 asection * section,
1611 void * scnhdr)
252b5132
RH
1612{
1613 struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1614 unsigned int i;
1615
1616#ifdef I960
ed781d5d 1617 /* Extract ALIGN from 2**ALIGN stored in section header. */
252b5132
RH
1618 for (i = 0; i < 32; i++)
1619 if ((1 << i) >= hdr->s_align)
1620 break;
1621#endif
1622#ifdef TIC80COFF
ed781d5d 1623 /* TI tools puts the alignment power in bits 8-11. */
252b5132 1624 i = (hdr->s_flags >> 8) & 0xF ;
81635ce4
TW
1625#endif
1626#ifdef COFF_DECODE_ALIGNMENT
1627 i = COFF_DECODE_ALIGNMENT(hdr->s_flags);
252b5132
RH
1628#endif
1629 section->alignment_power = i;
b9af77f5
TW
1630
1631#ifdef coff_set_section_load_page
1632 coff_set_section_load_page (section, hdr->s_page);
1633#endif
252b5132
RH
1634}
1635
1636#else /* ! COFF_ALIGN_IN_SECTION_HEADER */
1637#ifdef COFF_WITH_PE
1638
252b5132 1639static void
7920ce38
NC
1640coff_set_alignment_hook (bfd * abfd ATTRIBUTE_UNUSED,
1641 asection * section,
1642 void * scnhdr)
252b5132
RH
1643{
1644 struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
dc810e39 1645 bfd_size_type amt;
bd33be6e
L
1646 unsigned int alignment_power_const
1647 = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
252b5132 1648
bd33be6e
L
1649 switch (alignment_power_const)
1650 {
1651 case IMAGE_SCN_ALIGN_8192BYTES:
1652 case IMAGE_SCN_ALIGN_4096BYTES:
1653 case IMAGE_SCN_ALIGN_2048BYTES:
1654 case IMAGE_SCN_ALIGN_1024BYTES:
1655 case IMAGE_SCN_ALIGN_512BYTES:
1656 case IMAGE_SCN_ALIGN_256BYTES:
1657 case IMAGE_SCN_ALIGN_128BYTES:
1658 case IMAGE_SCN_ALIGN_64BYTES:
1659 case IMAGE_SCN_ALIGN_32BYTES:
1660 case IMAGE_SCN_ALIGN_16BYTES:
1661 case IMAGE_SCN_ALIGN_8BYTES:
1662 case IMAGE_SCN_ALIGN_4BYTES:
1663 case IMAGE_SCN_ALIGN_2BYTES:
1664 case IMAGE_SCN_ALIGN_1BYTES:
1665 section->alignment_power
1666 = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1667 break;
1668 default:
1669 break;
1670 }
252b5132 1671
252b5132 1672 /* In a PE image file, the s_paddr field holds the virtual size of a
8d3ad4e1
ILT
1673 section, while the s_size field holds the raw size. We also keep
1674 the original section flag value, since not every bit can be
1675 mapped onto a generic BFD section bit. */
1676 if (coff_section_data (abfd, section) == NULL)
252b5132 1677 {
dc810e39 1678 amt = sizeof (struct coff_section_tdata);
7920ce38 1679 section->used_by_bfd = bfd_zalloc (abfd, amt);
8d3ad4e1 1680 if (section->used_by_bfd == NULL)
7920ce38
NC
1681 /* FIXME: Return error. */
1682 abort ();
8d3ad4e1 1683 }
7920ce38 1684
8d3ad4e1
ILT
1685 if (pei_section_data (abfd, section) == NULL)
1686 {
dc810e39 1687 amt = sizeof (struct pei_section_tdata);
7920ce38 1688 coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
8d3ad4e1 1689 if (coff_section_data (abfd, section)->tdata == NULL)
7920ce38
NC
1690 /* FIXME: Return error. */
1691 abort ();
252b5132 1692 }
8d3ad4e1
ILT
1693 pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1694 pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
252b5132 1695
9d8cefa9 1696 section->lma = hdr->s_vaddr;
3e4554a2 1697
ed781d5d 1698 /* Check for extended relocs. */
3e4554a2
DD
1699 if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1700 {
1701 struct external_reloc dst;
1702 struct internal_reloc n;
dc810e39 1703 file_ptr oldpos = bfd_tell (abfd);
cd339148
NS
1704 bfd_size_type relsz = bfd_coff_relsz (abfd);
1705
dc810e39 1706 bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0);
7920ce38 1707 if (bfd_bread (& dst, relsz, abfd) != relsz)
3e4554a2 1708 return;
e60b52c6 1709
3e4554a2
DD
1710 coff_swap_reloc_in (abfd, &dst, &n);
1711 bfd_seek (abfd, oldpos, 0);
cd339148
NS
1712 section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1713 section->rel_filepos += relsz;
3e4554a2 1714 }
cd339148
NS
1715 else if (hdr->s_nreloc == 0xffff)
1716 (*_bfd_error_handler)
1717 ("%s: warning: claims to have 0xffff relocs, without overflow",
1718 bfd_get_filename (abfd));
252b5132
RH
1719}
1720#undef ALIGN_SET
1721#undef ELIFALIGN_SET
1722
1723#else /* ! COFF_WITH_PE */
1724#ifdef RS6000COFF_C
1725
1726/* We grossly abuse this function to handle XCOFF overflow headers.
1727 When we see one, we correct the reloc and line number counts in the
1728 real header, and remove the section we just created. */
1729
252b5132 1730static void
7920ce38 1731coff_set_alignment_hook (bfd *abfd, asection *section, void * scnhdr)
252b5132
RH
1732{
1733 struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1734 asection *real_sec;
252b5132
RH
1735
1736 if ((hdr->s_flags & STYP_OVRFLO) == 0)
1737 return;
1738
dc810e39 1739 real_sec = coff_section_from_bfd_index (abfd, (int) hdr->s_nreloc);
252b5132
RH
1740 if (real_sec == NULL)
1741 return;
1742
1743 real_sec->reloc_count = hdr->s_paddr;
1744 real_sec->lineno_count = hdr->s_vaddr;
1745
5daa8fe7 1746 if (!bfd_section_removed_from_list (abfd, section))
252b5132 1747 {
5daa8fe7
L
1748 bfd_section_list_remove (abfd, section);
1749 --abfd->section_count;
252b5132
RH
1750 }
1751}
1752
1753#else /* ! RS6000COFF_C */
1754
1755#define coff_set_alignment_hook \
7920ce38 1756 ((void (*) (bfd *, asection *, void *)) bfd_void)
252b5132
RH
1757
1758#endif /* ! RS6000COFF_C */
1759#endif /* ! COFF_WITH_PE */
1760#endif /* ! COFF_ALIGN_IN_SECTION_HEADER */
1761
1762#ifndef coff_mkobject
1763
b34976b6 1764static bfd_boolean
7920ce38 1765coff_mkobject (bfd * abfd)
252b5132
RH
1766{
1767 coff_data_type *coff;
dc810e39 1768 bfd_size_type amt = sizeof (coff_data_type);
252b5132 1769
7920ce38
NC
1770 abfd->tdata.coff_obj_data = bfd_zalloc (abfd, amt);
1771 if (abfd->tdata.coff_obj_data == NULL)
b34976b6 1772 return FALSE;
252b5132 1773 coff = coff_data (abfd);
7920ce38
NC
1774 coff->symbols = NULL;
1775 coff->conversion_table = NULL;
1776 coff->raw_syments = NULL;
252b5132
RH
1777 coff->relocbase = 0;
1778 coff->local_toc_sym_map = 0;
1779
1780/* make_abs_section(abfd);*/
1781
b34976b6 1782 return TRUE;
252b5132
RH
1783}
1784#endif
1785
1786/* Create the COFF backend specific information. */
ed781d5d 1787
252b5132 1788#ifndef coff_mkobject_hook
7920ce38
NC
1789static void *
1790coff_mkobject_hook (bfd * abfd,
1791 void * filehdr,
1792 void * aouthdr ATTRIBUTE_UNUSED)
252b5132
RH
1793{
1794 struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1795 coff_data_type *coff;
1796
82e51918 1797 if (! coff_mkobject (abfd))
252b5132
RH
1798 return NULL;
1799
1800 coff = coff_data (abfd);
1801
1802 coff->sym_filepos = internal_f->f_symptr;
1803
1804 /* These members communicate important constants about the symbol
1805 table to GDB's symbol-reading code. These `constants'
1806 unfortunately vary among coff implementations... */
1807 coff->local_n_btmask = N_BTMASK;
1808 coff->local_n_btshft = N_BTSHFT;
1809 coff->local_n_tmask = N_TMASK;
1810 coff->local_n_tshift = N_TSHIFT;
6b3b007b
NC
1811 coff->local_symesz = bfd_coff_symesz (abfd);
1812 coff->local_auxesz = bfd_coff_auxesz (abfd);
1813 coff->local_linesz = bfd_coff_linesz (abfd);
252b5132 1814
1135238b
ILT
1815 coff->timestamp = internal_f->f_timdat;
1816
252b5132
RH
1817 obj_raw_syment_count (abfd) =
1818 obj_conv_table_size (abfd) =
1819 internal_f->f_nsyms;
1820
1821#ifdef RS6000COFF_C
1822 if ((internal_f->f_flags & F_SHROBJ) != 0)
1823 abfd->flags |= DYNAMIC;
6b3b007b 1824 if (aouthdr != NULL && internal_f->f_opthdr >= bfd_coff_aoutsz (abfd))
252b5132
RH
1825 {
1826 struct internal_aouthdr *internal_a =
1827 (struct internal_aouthdr *) aouthdr;
1828 struct xcoff_tdata *xcoff;
1829
1830 xcoff = xcoff_data (abfd);
a2fdf270
ND
1831# ifdef U803XTOCMAGIC
1832 xcoff->xcoff64 = internal_f->f_magic == U803XTOCMAGIC;
1833# else
1834 xcoff->xcoff64 = 0;
1835# endif
b34976b6 1836 xcoff->full_aouthdr = TRUE;
252b5132
RH
1837 xcoff->toc = internal_a->o_toc;
1838 xcoff->sntoc = internal_a->o_sntoc;
1839 xcoff->snentry = internal_a->o_snentry;
f3813499
TR
1840 bfd_xcoff_text_align_power (abfd) = internal_a->o_algntext;
1841 bfd_xcoff_data_align_power (abfd) = internal_a->o_algndata;
252b5132
RH
1842 xcoff->modtype = internal_a->o_modtype;
1843 xcoff->cputype = internal_a->o_cputype;
1844 xcoff->maxdata = internal_a->o_maxdata;
1845 xcoff->maxstack = internal_a->o_maxstack;
1846 }
1847#endif
1848
e60b52c6 1849#ifdef ARM
f13b834e 1850 /* Set the flags field from the COFF header read in. */
252b5132
RH
1851 if (! _bfd_coff_arm_set_private_flags (abfd, internal_f->f_flags))
1852 coff->flags = 0;
1853#endif
e60b52c6 1854
4cfec37b
ILT
1855#ifdef COFF_WITH_PE
1856 /* FIXME: I'm not sure this is ever executed, since peicode.h
1857 defines coff_mkobject_hook. */
1858 if ((internal_f->f_flags & IMAGE_FILE_DEBUG_STRIPPED) == 0)
1859 abfd->flags |= HAS_DEBUG;
1860#endif
1861
7920ce38 1862 return coff;
252b5132
RH
1863}
1864#endif
1865
1866/* Determine the machine architecture and type. FIXME: This is target
1867 dependent because the magic numbers are defined in the target
1868 dependent header files. But there is no particular need for this.
1869 If the magic numbers were moved to a separate file, this function
1870 would be target independent and would also be much more successful
1871 at linking together COFF files for different architectures. */
1872
b34976b6 1873static bfd_boolean
7920ce38 1874coff_set_arch_mach_hook (bfd *abfd, void * filehdr)
252b5132 1875{
dc810e39 1876 unsigned long machine;
252b5132
RH
1877 enum bfd_architecture arch;
1878 struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1879
250d94fd 1880 /* Zero selects the default machine for an arch. */
252b5132
RH
1881 machine = 0;
1882 switch (internal_f->f_magic)
1883 {
3b16e843
NC
1884#ifdef OR32_MAGIC_BIG
1885 case OR32_MAGIC_BIG:
1886 case OR32_MAGIC_LITTLE:
1887 arch = bfd_arch_or32;
3b16e843
NC
1888 break;
1889#endif
252b5132
RH
1890#ifdef PPCMAGIC
1891 case PPCMAGIC:
1892 arch = bfd_arch_powerpc;
e60b52c6 1893 break;
252b5132
RH
1894#endif
1895#ifdef I386MAGIC
1896 case I386MAGIC:
1897 case I386PTXMAGIC:
99ad8390
NC
1898 case I386AIXMAGIC: /* Danbury PS/2 AIX C Compiler. */
1899 case LYNXCOFFMAGIC: /* Shadows the m68k Lynx number below, sigh. */
252b5132 1900 arch = bfd_arch_i386;
252b5132
RH
1901 break;
1902#endif
99ad8390
NC
1903#ifdef AMD64MAGIC
1904 case AMD64MAGIC:
1905 arch = bfd_arch_i386;
1906 machine = bfd_mach_x86_64;
1907 break;
1908#endif
fac41780
JW
1909#ifdef IA64MAGIC
1910 case IA64MAGIC:
1911 arch = bfd_arch_ia64;
fac41780
JW
1912 break;
1913#endif
252b5132
RH
1914#ifdef ARMMAGIC
1915 case ARMMAGIC:
17505c5c
NC
1916 case ARMPEMAGIC:
1917 case THUMBPEMAGIC:
252b5132 1918 arch = bfd_arch_arm;
5a6c6817
NC
1919 machine = bfd_arm_get_mach_from_notes (abfd, ARM_NOTE_SECTION);
1920 if (machine == bfd_mach_arm_unknown)
252b5132 1921 {
5a6c6817
NC
1922 switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
1923 {
1924 case F_ARM_2: machine = bfd_mach_arm_2; break;
1925 case F_ARM_2a: machine = bfd_mach_arm_2a; break;
1926 case F_ARM_3: machine = bfd_mach_arm_3; break;
1927 default:
1928 case F_ARM_3M: machine = bfd_mach_arm_3M; break;
1929 case F_ARM_4: machine = bfd_mach_arm_4; break;
1930 case F_ARM_4T: machine = bfd_mach_arm_4T; break;
1931 /* The COFF header does not have enough bits available
1932 to cover all the different ARM architectures. So
1933 we interpret F_ARM_5, the highest flag value to mean
1934 "the highest ARM architecture known to BFD" which is
1935 currently the XScale. */
1936 case F_ARM_5: machine = bfd_mach_arm_XScale; break;
1937 }
252b5132
RH
1938 }
1939 break;
1940#endif
1941#ifdef MC68MAGIC
1942 case MC68MAGIC:
1943 case M68MAGIC:
1944#ifdef MC68KBCSMAGIC
1945 case MC68KBCSMAGIC:
1946#endif
1947#ifdef APOLLOM68KMAGIC
1948 case APOLLOM68KMAGIC:
1949#endif
1950#ifdef LYNXCOFFMAGIC
1951 case LYNXCOFFMAGIC:
1952#endif
1953 arch = bfd_arch_m68k;
1954 machine = bfd_mach_m68020;
1955 break;
1956#endif
7499d566
NC
1957#ifdef MAXQ20MAGIC
1958 case MAXQ20MAGIC:
1959 arch = bfd_arch_maxq;
5c4504f7
NC
1960 switch (internal_f->f_flags & F_MACHMASK)
1961 {
1962 case F_MAXQ10:
1963 machine = bfd_mach_maxq10;
1964 break;
1965 case F_MAXQ20:
1966 machine = bfd_mach_maxq20;
1967 break;
1968 default:
1969 return FALSE;
1970 }
7499d566
NC
1971 break;
1972#endif
252b5132
RH
1973#ifdef MC88MAGIC
1974 case MC88MAGIC:
1975 case MC88DMAGIC:
1976 case MC88OMAGIC:
1977 arch = bfd_arch_m88k;
1978 machine = 88100;
1979 break;
1980#endif
3c9b82ba
NC
1981#ifdef Z80MAGIC
1982 case Z80MAGIC:
1983 arch = bfd_arch_z80;
1984 switch (internal_f->f_flags & F_MACHMASK)
1985 {
1986 case 0:
1987 case bfd_mach_z80strict << 12:
1988 case bfd_mach_z80 << 12:
1989 case bfd_mach_z80full << 12:
1990 case bfd_mach_r800 << 12:
1991 machine = ((unsigned)internal_f->f_flags & F_MACHMASK) >> 12;
1992 break;
1993 default:
1994 return FALSE;
1995 }
1996 break;
1997#endif
252b5132
RH
1998#ifdef Z8KMAGIC
1999 case Z8KMAGIC:
2000 arch = bfd_arch_z8k;
2001 switch (internal_f->f_flags & F_MACHMASK)
2002 {
2003 case F_Z8001:
2004 machine = bfd_mach_z8001;
2005 break;
2006 case F_Z8002:
2007 machine = bfd_mach_z8002;
2008 break;
2009 default:
b34976b6 2010 return FALSE;
252b5132
RH
2011 }
2012 break;
2013#endif
2014#ifdef I860
2015 case I860MAGIC:
2016 arch = bfd_arch_i860;
2017 break;
2018#endif
2019#ifdef I960
2020#ifdef I960ROMAGIC
2021 case I960ROMAGIC:
2022 case I960RWMAGIC:
2023 arch = bfd_arch_i960;
2024 switch (F_I960TYPE & internal_f->f_flags)
2025 {
2026 default:
2027 case F_I960CORE:
2028 machine = bfd_mach_i960_core;
2029 break;
2030 case F_I960KB:
2031 machine = bfd_mach_i960_kb_sb;
2032 break;
2033 case F_I960MC:
2034 machine = bfd_mach_i960_mc;
2035 break;
2036 case F_I960XA:
2037 machine = bfd_mach_i960_xa;
2038 break;
2039 case F_I960CA:
2040 machine = bfd_mach_i960_ca;
2041 break;
2042 case F_I960KA:
2043 machine = bfd_mach_i960_ka_sa;
2044 break;
2045 case F_I960JX:
2046 machine = bfd_mach_i960_jx;
2047 break;
2048 case F_I960HX:
2049 machine = bfd_mach_i960_hx;
2050 break;
2051 }
2052 break;
2053#endif
2054#endif
2055
2056#ifdef RS6000COFF_C
7f6d05e8 2057#ifdef XCOFF64
eb1e0e80 2058 case U64_TOCMAGIC:
c6664dfb 2059 case U803XTOCMAGIC:
7f6d05e8 2060#else
252b5132
RH
2061 case U802ROMAGIC:
2062 case U802WRMAGIC:
2063 case U802TOCMAGIC:
7f6d05e8 2064#endif
252b5132
RH
2065 {
2066 int cputype;
2067
2068 if (xcoff_data (abfd)->cputype != -1)
2069 cputype = xcoff_data (abfd)->cputype & 0xff;
2070 else
2071 {
2072 /* We did not get a value from the a.out header. If the
2073 file has not been stripped, we may be able to get the
2074 architecture information from the first symbol, if it
2075 is a .file symbol. */
2076 if (obj_raw_syment_count (abfd) == 0)
2077 cputype = 0;
2078 else
2079 {
5ea1af0d 2080 bfd_byte *buf;
252b5132 2081 struct internal_syment sym;
dc810e39 2082 bfd_size_type amt = bfd_coff_symesz (abfd);
252b5132 2083
7920ce38 2084 buf = bfd_malloc (amt);
252b5132 2085 if (bfd_seek (abfd, obj_sym_filepos (abfd), SEEK_SET) != 0
dc810e39 2086 || bfd_bread (buf, amt, abfd) != amt)
5ea1af0d 2087 {
2fca4467 2088 free (buf);
b34976b6 2089 return FALSE;
5ea1af0d 2090 }
7920ce38 2091 bfd_coff_swap_sym_in (abfd, buf, & sym);
252b5132
RH
2092 if (sym.n_sclass == C_FILE)
2093 cputype = sym.n_type & 0xff;
2094 else
2095 cputype = 0;
2fca4467 2096 free (buf);
252b5132
RH
2097 }
2098 }
2099
2100 /* FIXME: We don't handle all cases here. */
2101 switch (cputype)
2102 {
2103 default:
2104 case 0:
beb1bf64
TR
2105 arch = bfd_xcoff_architecture (abfd);
2106 machine = bfd_xcoff_machine (abfd);
252b5132
RH
2107 break;
2108
2109 case 1:
2110 arch = bfd_arch_powerpc;
87f33987 2111 machine = bfd_mach_ppc_601;
252b5132
RH
2112 break;
2113 case 2: /* 64 bit PowerPC */
2114 arch = bfd_arch_powerpc;
87f33987 2115 machine = bfd_mach_ppc_620;
252b5132
RH
2116 break;
2117 case 3:
2118 arch = bfd_arch_powerpc;
87f33987 2119 machine = bfd_mach_ppc;
252b5132
RH
2120 break;
2121 case 4:
2122 arch = bfd_arch_rs6000;
87f33987 2123 machine = bfd_mach_rs6k;
252b5132
RH
2124 break;
2125 }
2126 }
2127 break;
2128#endif
2129
2130#ifdef WE32KMAGIC
2131 case WE32KMAGIC:
2132 arch = bfd_arch_we32k;
252b5132
RH
2133 break;
2134#endif
2135
2136#ifdef H8300MAGIC
2137 case H8300MAGIC:
2138 arch = bfd_arch_h8300;
2139 machine = bfd_mach_h8300;
8d9cd6b1 2140 /* !! FIXME this probably isn't the right place for this. */
252b5132
RH
2141 abfd->flags |= BFD_IS_RELAXABLE;
2142 break;
2143#endif
2144
2145#ifdef H8300HMAGIC
2146 case H8300HMAGIC:
2147 arch = bfd_arch_h8300;
2148 machine = bfd_mach_h8300h;
8d9cd6b1 2149 /* !! FIXME this probably isn't the right place for this. */
252b5132
RH
2150 abfd->flags |= BFD_IS_RELAXABLE;
2151 break;
2152#endif
2153
2154#ifdef H8300SMAGIC
2155 case H8300SMAGIC:
2156 arch = bfd_arch_h8300;
2157 machine = bfd_mach_h8300s;
8d9cd6b1
NC
2158 /* !! FIXME this probably isn't the right place for this. */
2159 abfd->flags |= BFD_IS_RELAXABLE;
2160 break;
2161#endif
2162
2163#ifdef H8300HNMAGIC
2164 case H8300HNMAGIC:
2165 arch = bfd_arch_h8300;
2166 machine = bfd_mach_h8300hn;
2167 /* !! FIXME this probably isn't the right place for this. */
2168 abfd->flags |= BFD_IS_RELAXABLE;
2169 break;
2170#endif
2171
2172#ifdef H8300SNMAGIC
2173 case H8300SNMAGIC:
2174 arch = bfd_arch_h8300;
2175 machine = bfd_mach_h8300sn;
2176 /* !! FIXME this probably isn't the right place for this. */
252b5132
RH
2177 abfd->flags |= BFD_IS_RELAXABLE;
2178 break;
2179#endif
2180
2181#ifdef SH_ARCH_MAGIC_BIG
2182 case SH_ARCH_MAGIC_BIG:
2183 case SH_ARCH_MAGIC_LITTLE:
17505c5c
NC
2184#ifdef COFF_WITH_PE
2185 case SH_ARCH_MAGIC_WINCE:
2186#endif
252b5132 2187 arch = bfd_arch_sh;
252b5132
RH
2188 break;
2189#endif
2190
17505c5c
NC
2191#ifdef MIPS_ARCH_MAGIC_WINCE
2192 case MIPS_ARCH_MAGIC_WINCE:
2193 arch = bfd_arch_mips;
17505c5c
NC
2194 break;
2195#endif
2196
252b5132
RH
2197#ifdef H8500MAGIC
2198 case H8500MAGIC:
2199 arch = bfd_arch_h8500;
252b5132
RH
2200 break;
2201#endif
2202
2203#ifdef SPARCMAGIC
2204 case SPARCMAGIC:
2205#ifdef LYNXCOFFMAGIC
2206 case LYNXCOFFMAGIC:
2207#endif
2208 arch = bfd_arch_sparc;
252b5132
RH
2209 break;
2210#endif
2211
2212#ifdef TIC30MAGIC
2213 case TIC30MAGIC:
2214 arch = bfd_arch_tic30;
2215 break;
2216#endif
2217
81635ce4
TW
2218#ifdef TICOFF0MAGIC
2219#ifdef TICOFF_TARGET_ARCH
ed781d5d 2220 /* This TI COFF section should be used by all new TI COFF v0 targets. */
81635ce4
TW
2221 case TICOFF0MAGIC:
2222 arch = TICOFF_TARGET_ARCH;
0da35f8b 2223 machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
81635ce4
TW
2224 break;
2225#endif
2226#endif
2227
2228#ifdef TICOFF1MAGIC
ed781d5d
NC
2229 /* This TI COFF section should be used by all new TI COFF v1/2 targets. */
2230 /* TI COFF1 and COFF2 use the target_id field to specify which arch. */
81635ce4
TW
2231 case TICOFF1MAGIC:
2232 case TICOFF2MAGIC:
2233 switch (internal_f->f_target_id)
2234 {
2235#ifdef TI_TARGET_ID
2236 case TI_TARGET_ID:
2237 arch = TICOFF_TARGET_ARCH;
0da35f8b 2238 machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
81635ce4
TW
2239 break;
2240#endif
2241 default:
4af1d5f6 2242 arch = bfd_arch_obscure;
81635ce4 2243 (*_bfd_error_handler)
e60b52c6 2244 (_("Unrecognized TI COFF target id '0x%x'"),
81635ce4
TW
2245 internal_f->f_target_id);
2246 break;
2247 }
2248 break;
2249#endif
2250
252b5132
RH
2251#ifdef TIC80_ARCH_MAGIC
2252 case TIC80_ARCH_MAGIC:
2253 arch = bfd_arch_tic80;
2254 break;
2255#endif
2256
2257#ifdef MCOREMAGIC
2258 case MCOREMAGIC:
2259 arch = bfd_arch_mcore;
2260 break;
2261#endif
c8e48751
AM
2262
2263#ifdef W65MAGIC
2264 case W65MAGIC:
2265 arch = bfd_arch_w65;
2266 break;
2267#endif
2268
ed781d5d 2269 default: /* Unreadable input file type. */
252b5132
RH
2270 arch = bfd_arch_obscure;
2271 break;
2272 }
2273
2274 bfd_default_set_arch_mach (abfd, arch, machine);
b34976b6 2275 return TRUE;
252b5132
RH
2276}
2277
2278#ifdef SYMNAME_IN_DEBUG
2279
b34976b6 2280static bfd_boolean
7920ce38 2281symname_in_debug_hook (bfd * abfd ATTRIBUTE_UNUSED, struct internal_syment *sym)
252b5132 2282{
82e51918 2283 return SYMNAME_IN_DEBUG (sym) != 0;
252b5132
RH
2284}
2285
2286#else
2287
2288#define symname_in_debug_hook \
7920ce38 2289 (bfd_boolean (*) (bfd *, struct internal_syment *)) bfd_false
252b5132
RH
2290
2291#endif
2292
2293#ifdef RS6000COFF_C
2294
7f6d05e8
CP
2295#ifdef XCOFF64
2296#define FORCE_SYMNAMES_IN_STRINGS
2297#endif
a022216b 2298
252b5132
RH
2299/* Handle the csect auxent of a C_EXT or C_HIDEXT symbol. */
2300
b34976b6 2301static bfd_boolean
7920ce38
NC
2302coff_pointerize_aux_hook (bfd *abfd ATTRIBUTE_UNUSED,
2303 combined_entry_type *table_base,
2304 combined_entry_type *symbol,
2305 unsigned int indaux,
2306 combined_entry_type *aux)
252b5132
RH
2307{
2308 int class = symbol->u.syment.n_sclass;
2309
2310 if ((class == C_EXT || class == C_HIDEXT)
2311 && indaux + 1 == symbol->u.syment.n_numaux)
2312 {
2313 if (SMTYP_SMTYP (aux->u.auxent.x_csect.x_smtyp) == XTY_LD)
2314 {
2315 aux->u.auxent.x_csect.x_scnlen.p =
2316 table_base + aux->u.auxent.x_csect.x_scnlen.l;
2317 aux->fix_scnlen = 1;
2318 }
2319
b34976b6 2320 /* Return TRUE to indicate that the caller should not do any
252b5132 2321 further work on this auxent. */
b34976b6 2322 return TRUE;
252b5132
RH
2323 }
2324
b34976b6 2325 /* Return FALSE to indicate that this auxent should be handled by
252b5132 2326 the caller. */
b34976b6 2327 return FALSE;
252b5132
RH
2328}
2329
2330#else
2331#ifdef I960
2332
2333/* We don't want to pointerize bal entries. */
2334
b34976b6 2335static bfd_boolean
7920ce38
NC
2336coff_pointerize_aux_hook (bfd *abfd ATTRIBUTE_UNUSED,
2337 combined_entry_type *table_base ATTRIBUTE_UNUSED,
2338 combined_entry_type *symbol,
2339 unsigned int indaux,
2340 combined_entry_type *aux ATTRIBUTE_UNUSED)
252b5132 2341{
b34976b6 2342 /* Return TRUE if we don't want to pointerize this aux entry, which
252b5132
RH
2343 is the case for the lastfirst aux entry for a C_LEAFPROC symbol. */
2344 return (indaux == 1
2345 && (symbol->u.syment.n_sclass == C_LEAFPROC
2346 || symbol->u.syment.n_sclass == C_LEAFSTAT
2347 || symbol->u.syment.n_sclass == C_LEAFEXT));
2348}
2349
2350#else /* ! I960 */
2351
2352#define coff_pointerize_aux_hook 0
2353
2354#endif /* ! I960 */
2355#endif /* ! RS6000COFF_C */
2356
b34976b6 2357/* Print an aux entry. This returns TRUE if it has printed it. */
252b5132 2358
b34976b6 2359static bfd_boolean
7920ce38
NC
2360coff_print_aux (bfd *abfd ATTRIBUTE_UNUSED,
2361 FILE *file ATTRIBUTE_UNUSED,
2362 combined_entry_type *table_base ATTRIBUTE_UNUSED,
2363 combined_entry_type *symbol ATTRIBUTE_UNUSED,
2364 combined_entry_type *aux ATTRIBUTE_UNUSED,
2365 unsigned int indaux ATTRIBUTE_UNUSED)
252b5132
RH
2366{
2367#ifdef RS6000COFF_C
2368 if ((symbol->u.syment.n_sclass == C_EXT
2369 || symbol->u.syment.n_sclass == C_HIDEXT)
2370 && indaux + 1 == symbol->u.syment.n_numaux)
2371 {
2372 /* This is a csect entry. */
2373 fprintf (file, "AUX ");
2374 if (SMTYP_SMTYP (aux->u.auxent.x_csect.x_smtyp) != XTY_LD)
2375 {
2376 BFD_ASSERT (! aux->fix_scnlen);
dc810e39 2377#ifdef XCOFF64
f60ca5e3
AM
2378 fprintf (file, "val %5lld",
2379 (long long) aux->u.auxent.x_csect.x_scnlen.l);
beb1bf64
TR
2380#else
2381 fprintf (file, "val %5ld", (long) aux->u.auxent.x_csect.x_scnlen.l);
2382#endif
252b5132
RH
2383 }
2384 else
2385 {
2386 fprintf (file, "indx ");
2387 if (! aux->fix_scnlen)
beb1bf64 2388#ifdef XCOFF64
f60ca5e3
AM
2389 fprintf (file, "%4lld",
2390 (long long) aux->u.auxent.x_csect.x_scnlen.l);
beb1bf64
TR
2391#else
2392 fprintf (file, "%4ld", (long) aux->u.auxent.x_csect.x_scnlen.l);
2393#endif
252b5132
RH
2394 else
2395 fprintf (file, "%4ld",
2396 (long) (aux->u.auxent.x_csect.x_scnlen.p - table_base));
2397 }
2398 fprintf (file,
2399 " prmhsh %ld snhsh %u typ %d algn %d clss %u stb %ld snstb %u",
2400 aux->u.auxent.x_csect.x_parmhash,
2401 (unsigned int) aux->u.auxent.x_csect.x_snhash,
2402 SMTYP_SMTYP (aux->u.auxent.x_csect.x_smtyp),
2403 SMTYP_ALIGN (aux->u.auxent.x_csect.x_smtyp),
2404 (unsigned int) aux->u.auxent.x_csect.x_smclas,
2405 aux->u.auxent.x_csect.x_stab,
2406 (unsigned int) aux->u.auxent.x_csect.x_snstab);
b34976b6 2407 return TRUE;
252b5132
RH
2408 }
2409#endif
2410
b34976b6
AM
2411 /* Return FALSE to indicate that no special action was taken. */
2412 return FALSE;
252b5132
RH
2413}
2414
2415/*
2416SUBSUBSECTION
2417 Writing relocations
2418
2419 To write relocations, the back end steps though the
2420 canonical relocation table and create an
2421 @code{internal_reloc}. The symbol index to use is removed from
2422 the @code{offset} field in the symbol table supplied. The
2423 address comes directly from the sum of the section base
2424 address and the relocation offset; the type is dug directly
2425 from the howto field. Then the @code{internal_reloc} is
2426 swapped into the shape of an @code{external_reloc} and written
2427 out to disk.
2428
2429*/
2430
2431#ifdef TARG_AUX
2432
252b5132 2433
ed781d5d 2434/* AUX's ld wants relocations to be sorted. */
252b5132 2435static int
7920ce38 2436compare_arelent_ptr (const void * x, const void * y)
252b5132
RH
2437{
2438 const arelent **a = (const arelent **) x;
2439 const arelent **b = (const arelent **) y;
2440 bfd_size_type aadr = (*a)->address;
2441 bfd_size_type badr = (*b)->address;
2442
2443 return (aadr < badr ? -1 : badr < aadr ? 1 : 0);
2444}
2445
2446#endif /* TARG_AUX */
2447
b34976b6 2448static bfd_boolean
7920ce38 2449coff_write_relocs (bfd * abfd, int first_undef)
252b5132
RH
2450{
2451 asection *s;
2452
7920ce38 2453 for (s = abfd->sections; s != NULL; s = s->next)
252b5132
RH
2454 {
2455 unsigned int i;
2456 struct external_reloc dst;
2457 arelent **p;
2458
2459#ifndef TARG_AUX
2460 p = s->orelocation;
2461#else
dc810e39 2462 {
ed781d5d 2463 /* Sort relocations before we write them out. */
dc810e39
AM
2464 bfd_size_type amt;
2465
2466 amt = s->reloc_count;
2467 amt *= sizeof (arelent *);
7920ce38 2468 p = bfd_malloc (amt);
dc810e39 2469 if (p == NULL && s->reloc_count > 0)
b34976b6 2470 return FALSE;
dc810e39
AM
2471 memcpy (p, s->orelocation, (size_t) amt);
2472 qsort (p, s->reloc_count, sizeof (arelent *), compare_arelent_ptr);
2473 }
252b5132
RH
2474#endif
2475
2476 if (bfd_seek (abfd, s->rel_filepos, SEEK_SET) != 0)
b34976b6 2477 return FALSE;
3e4554a2
DD
2478
2479#ifdef COFF_WITH_PE
e9168c1e 2480 if (obj_pe (abfd) && s->reloc_count >= 0xffff)
3e4554a2 2481 {
ed781d5d 2482 /* Encode real count here as first reloc. */
3e4554a2 2483 struct internal_reloc n;
ed781d5d 2484
7920ce38 2485 memset (& n, 0, sizeof (n));
ed781d5d 2486 /* Add one to count *this* reloc (grr). */
3e4554a2
DD
2487 n.r_vaddr = s->reloc_count + 1;
2488 coff_swap_reloc_out (abfd, &n, &dst);
7920ce38
NC
2489 if (bfd_bwrite (& dst, (bfd_size_type) bfd_coff_relsz (abfd),
2490 abfd) != bfd_coff_relsz (abfd))
b34976b6 2491 return FALSE;
3e4554a2
DD
2492 }
2493#endif
2494
252b5132
RH
2495 for (i = 0; i < s->reloc_count; i++)
2496 {
2497 struct internal_reloc n;
2498 arelent *q = p[i];
ed781d5d 2499
7920ce38 2500 memset (& n, 0, sizeof (n));
252b5132
RH
2501
2502 /* Now we've renumbered the symbols we know where the
2503 undefined symbols live in the table. Check the reloc
2504 entries for symbols who's output bfd isn't the right one.
2505 This is because the symbol was undefined (which means
2506 that all the pointers are never made to point to the same
2507 place). This is a bad thing,'cause the symbols attached
2508 to the output bfd are indexed, so that the relocation
2509 entries know which symbol index they point to. So we
e60b52c6 2510 have to look up the output symbol here. */
252b5132
RH
2511
2512 if (q->sym_ptr_ptr[0]->the_bfd != abfd)
2513 {
dc810e39 2514 int j;
252b5132
RH
2515 const char *sname = q->sym_ptr_ptr[0]->name;
2516 asymbol **outsyms = abfd->outsymbols;
ed781d5d 2517
dc810e39 2518 for (j = first_undef; outsyms[j]; j++)
252b5132 2519 {
dc810e39 2520 const char *intable = outsyms[j]->name;
ed781d5d 2521
7920ce38
NC
2522 if (strcmp (intable, sname) == 0)
2523 {
2524 /* Got a hit, so repoint the reloc. */
2525 q->sym_ptr_ptr = outsyms + j;
2526 break;
2527 }
252b5132
RH
2528 }
2529 }
2530
2531 n.r_vaddr = q->address + s->vma;
2532
2533#ifdef R_IHCONST
2534 /* The 29k const/consth reloc pair is a real kludge. The consth
2535 part doesn't have a symbol; it has an offset. So rebuilt
2536 that here. */
2537 if (q->howto->type == R_IHCONST)
2538 n.r_symndx = q->addend;
2539 else
2540#endif
2541 if (q->sym_ptr_ptr)
2542 {
6c784c9a 2543#ifdef SECTION_RELATIVE_ABSOLUTE_SYMBOL_P
7920ce38 2544 if (SECTION_RELATIVE_ABSOLUTE_SYMBOL_P (q, s))
6c784c9a 2545#else
250d94fd
AM
2546 if ((*q->sym_ptr_ptr)->section == bfd_abs_section_ptr
2547 && ((*q->sym_ptr_ptr)->flags & BSF_SECTION_SYM) != 0)
6c784c9a 2548#endif
252b5132
RH
2549 /* This is a relocation relative to the absolute symbol. */
2550 n.r_symndx = -1;
2551 else
2552 {
2553 n.r_symndx = get_index ((*(q->sym_ptr_ptr)));
337ff0a5
NC
2554 /* Check to see if the symbol reloc points to a symbol
2555 we don't have in our symbol table. */
252b5132 2556 if (n.r_symndx > obj_conv_table_size (abfd))
337ff0a5
NC
2557 {
2558 bfd_set_error (bfd_error_bad_value);
2559 _bfd_error_handler (_("%B: reloc against a non-existant symbol index: %ld"),
2560 abfd, n.r_symndx);
2561 return FALSE;
2562 }
252b5132
RH
2563 }
2564 }
2565
2566#ifdef SWAP_OUT_RELOC_OFFSET
2567 n.r_offset = q->addend;
2568#endif
2569
2570#ifdef SELECT_RELOC
ed781d5d 2571 /* Work out reloc type from what is required. */
252b5132
RH
2572 SELECT_RELOC (n, q->howto);
2573#else
2574 n.r_type = q->howto->type;
2575#endif
2576 coff_swap_reloc_out (abfd, &n, &dst);
ed781d5d 2577
7920ce38 2578 if (bfd_bwrite (& dst, (bfd_size_type) bfd_coff_relsz (abfd),
dc810e39 2579 abfd) != bfd_coff_relsz (abfd))
b34976b6 2580 return FALSE;
252b5132
RH
2581 }
2582
2583#ifdef TARG_AUX
2584 if (p != NULL)
2585 free (p);
2586#endif
2587 }
2588
b34976b6 2589 return TRUE;
252b5132
RH
2590}
2591
2592/* Set flags and magic number of a coff file from architecture and machine
b34976b6 2593 type. Result is TRUE if we can represent the arch&type, FALSE if not. */
252b5132 2594
b34976b6 2595static bfd_boolean
7920ce38
NC
2596coff_set_flags (bfd * abfd,
2597 unsigned int *magicp ATTRIBUTE_UNUSED,
2598 unsigned short *flagsp ATTRIBUTE_UNUSED)
252b5132
RH
2599{
2600 switch (bfd_get_arch (abfd))
2601 {
3c9b82ba
NC
2602#ifdef Z80MAGIC
2603 case bfd_arch_z80:
2604 *magicp = Z80MAGIC;
2605 switch (bfd_get_mach (abfd))
2606 {
2607 case 0:
2608 case bfd_mach_z80strict:
2609 case bfd_mach_z80:
2610 case bfd_mach_z80full:
2611 case bfd_mach_r800:
2612 *flagsp = bfd_get_mach (abfd) << 12;
2613 break;
2614 default:
2615 return FALSE;
2616 }
2617 return TRUE;
2618#endif
2619
252b5132
RH
2620#ifdef Z8KMAGIC
2621 case bfd_arch_z8k:
2622 *magicp = Z8KMAGIC;
7920ce38 2623
252b5132
RH
2624 switch (bfd_get_mach (abfd))
2625 {
7920ce38
NC
2626 case bfd_mach_z8001: *flagsp = F_Z8001; break;
2627 case bfd_mach_z8002: *flagsp = F_Z8002; break;
2628 default: return FALSE;
252b5132 2629 }
b34976b6 2630 return TRUE;
252b5132 2631#endif
252b5132 2632
7920ce38 2633#ifdef I960ROMAGIC
252b5132
RH
2634 case bfd_arch_i960:
2635
2636 {
2637 unsigned flags;
7920ce38 2638
252b5132 2639 *magicp = I960ROMAGIC;
7920ce38 2640
252b5132
RH
2641 switch (bfd_get_mach (abfd))
2642 {
7920ce38
NC
2643 case bfd_mach_i960_core: flags = F_I960CORE; break;
2644 case bfd_mach_i960_kb_sb: flags = F_I960KB; break;
2645 case bfd_mach_i960_mc: flags = F_I960MC; break;
2646 case bfd_mach_i960_xa: flags = F_I960XA; break;
2647 case bfd_mach_i960_ca: flags = F_I960CA; break;
2648 case bfd_mach_i960_ka_sa: flags = F_I960KA; break;
2649 case bfd_mach_i960_jx: flags = F_I960JX; break;
2650 case bfd_mach_i960_hx: flags = F_I960HX; break;
2651 default: return FALSE;
252b5132
RH
2652 }
2653 *flagsp = flags;
b34976b6 2654 return TRUE;
252b5132
RH
2655 }
2656 break;
2657#endif
2658
2659#ifdef TIC30MAGIC
2660 case bfd_arch_tic30:
2661 *magicp = TIC30MAGIC;
b34976b6 2662 return TRUE;
252b5132 2663#endif
81635ce4
TW
2664
2665#ifdef TICOFF_DEFAULT_MAGIC
2666 case TICOFF_TARGET_ARCH:
ed781d5d 2667 /* If there's no indication of which version we want, use the default. */
81635ce4
TW
2668 if (!abfd->xvec )
2669 *magicp = TICOFF_DEFAULT_MAGIC;
2670 else
2671 {
ed781d5d 2672 /* We may want to output in a different COFF version. */
81635ce4
TW
2673 switch (abfd->xvec->name[4])
2674 {
2675 case '0':
2676 *magicp = TICOFF0MAGIC;
2677 break;
2678 case '1':
2679 *magicp = TICOFF1MAGIC;
2680 break;
2681 case '2':
2682 *magicp = TICOFF2MAGIC;
2683 break;
2684 default:
b34976b6 2685 return FALSE;
81635ce4
TW
2686 }
2687 }
0da35f8b 2688 TICOFF_TARGET_MACHINE_SET (flagsp, bfd_get_mach (abfd));
b34976b6 2689 return TRUE;
81635ce4
TW
2690#endif
2691
252b5132
RH
2692#ifdef TIC80_ARCH_MAGIC
2693 case bfd_arch_tic80:
2694 *magicp = TIC80_ARCH_MAGIC;
b34976b6 2695 return TRUE;
252b5132 2696#endif
7920ce38 2697
252b5132
RH
2698#ifdef ARMMAGIC
2699 case bfd_arch_arm:
17505c5c
NC
2700#ifdef ARM_WINCE
2701 * magicp = ARMPEMAGIC;
2702#else
252b5132 2703 * magicp = ARMMAGIC;
17505c5c 2704#endif
252b5132
RH
2705 * flagsp = 0;
2706 if (APCS_SET (abfd))
2707 {
2708 if (APCS_26_FLAG (abfd))
2709 * flagsp |= F_APCS26;
e60b52c6 2710
252b5132
RH
2711 if (APCS_FLOAT_FLAG (abfd))
2712 * flagsp |= F_APCS_FLOAT;
e60b52c6 2713
252b5132 2714 if (PIC_FLAG (abfd))
948221a8 2715 * flagsp |= F_PIC;
252b5132
RH
2716 }
2717 if (INTERWORK_SET (abfd) && INTERWORK_FLAG (abfd))
2718 * flagsp |= F_INTERWORK;
2719 switch (bfd_get_mach (abfd))
2720 {
2721 case bfd_mach_arm_2: * flagsp |= F_ARM_2; break;
2722 case bfd_mach_arm_2a: * flagsp |= F_ARM_2a; break;
2723 case bfd_mach_arm_3: * flagsp |= F_ARM_3; break;
2724 case bfd_mach_arm_3M: * flagsp |= F_ARM_3M; break;
2725 case bfd_mach_arm_4: * flagsp |= F_ARM_4; break;
2726 case bfd_mach_arm_4T: * flagsp |= F_ARM_4T; break;
478d07d6 2727 case bfd_mach_arm_5: * flagsp |= F_ARM_5; break;
f13b834e
NC
2728 /* FIXME: we do not have F_ARM vaues greater than F_ARM_5.
2729 See also the comment in coff_set_arch_mach_hook(). */
077b8428
NC
2730 case bfd_mach_arm_5T: * flagsp |= F_ARM_5; break;
2731 case bfd_mach_arm_5TE: * flagsp |= F_ARM_5; break;
2732 case bfd_mach_arm_XScale: * flagsp |= F_ARM_5; break;
252b5132 2733 }
b34976b6 2734 return TRUE;
252b5132 2735#endif
7920ce38 2736
252b5132
RH
2737#ifdef PPCMAGIC
2738 case bfd_arch_powerpc:
2739 *magicp = PPCMAGIC;
b34976b6 2740 return TRUE;
252b5132 2741#endif
7920ce38 2742
99ad8390 2743#if defined(I386MAGIC) || defined(AMD64MAGIC)
252b5132 2744 case bfd_arch_i386:
99ad8390 2745#if defined(I386MAGIC)
252b5132 2746 *magicp = I386MAGIC;
99ad8390
NC
2747#endif
2748#if defined LYNXOS
e60b52c6 2749 /* Just overwrite the usual value if we're doing Lynx. */
252b5132 2750 *magicp = LYNXCOFFMAGIC;
99ad8390
NC
2751#endif
2752#if defined AMD64MAGIC
2753 *magicp = AMD64MAGIC;
252b5132 2754#endif
b34976b6 2755 return TRUE;
252b5132 2756#endif
7920ce38 2757
252b5132
RH
2758#ifdef I860MAGIC
2759 case bfd_arch_i860:
2760 *magicp = I860MAGIC;
b34976b6 2761 return TRUE;
252b5132 2762#endif
7920ce38 2763
fac41780
JW
2764#ifdef IA64MAGIC
2765 case bfd_arch_ia64:
2766 *magicp = IA64MAGIC;
b34976b6 2767 return TRUE;
fac41780 2768#endif
7920ce38 2769
252b5132
RH
2770#ifdef MC68MAGIC
2771 case bfd_arch_m68k:
2772#ifdef APOLLOM68KMAGIC
2773 *magicp = APOLLO_COFF_VERSION_NUMBER;
2774#else
2775 /* NAMES_HAVE_UNDERSCORE may be defined by coff-u68k.c. */
2776#ifdef NAMES_HAVE_UNDERSCORE
2777 *magicp = MC68KBCSMAGIC;
2778#else
2779 *magicp = MC68MAGIC;
2780#endif
2781#endif
2782#ifdef LYNXOS
e60b52c6 2783 /* Just overwrite the usual value if we're doing Lynx. */
252b5132
RH
2784 *magicp = LYNXCOFFMAGIC;
2785#endif
b34976b6 2786 return TRUE;
252b5132
RH
2787#endif
2788
2789#ifdef MC88MAGIC
2790 case bfd_arch_m88k:
2791 *magicp = MC88OMAGIC;
b34976b6 2792 return TRUE;
252b5132 2793#endif
7920ce38 2794
252b5132
RH
2795#ifdef H8300MAGIC
2796 case bfd_arch_h8300:
2797 switch (bfd_get_mach (abfd))
2798 {
7920ce38
NC
2799 case bfd_mach_h8300: *magicp = H8300MAGIC; return TRUE;
2800 case bfd_mach_h8300h: *magicp = H8300HMAGIC; return TRUE;
2801 case bfd_mach_h8300s: *magicp = H8300SMAGIC; return TRUE;
2802 case bfd_mach_h8300hn: *magicp = H8300HNMAGIC; return TRUE;
2803 case bfd_mach_h8300sn: *magicp = H8300SNMAGIC; return TRUE;
2804 default: break;
252b5132
RH
2805 }
2806 break;
2807#endif
2808
2809#ifdef SH_ARCH_MAGIC_BIG
2810 case bfd_arch_sh:
17505c5c
NC
2811#ifdef COFF_IMAGE_WITH_PE
2812 *magicp = SH_ARCH_MAGIC_WINCE;
2813#else
252b5132
RH
2814 if (bfd_big_endian (abfd))
2815 *magicp = SH_ARCH_MAGIC_BIG;
2816 else
2817 *magicp = SH_ARCH_MAGIC_LITTLE;
17505c5c 2818#endif
b34976b6 2819 return TRUE;
17505c5c
NC
2820#endif
2821
2822#ifdef MIPS_ARCH_MAGIC_WINCE
2823 case bfd_arch_mips:
2824 *magicp = MIPS_ARCH_MAGIC_WINCE;
b34976b6 2825 return TRUE;
252b5132
RH
2826#endif
2827
2828#ifdef SPARCMAGIC
2829 case bfd_arch_sparc:
2830 *magicp = SPARCMAGIC;
2831#ifdef LYNXOS
e60b52c6 2832 /* Just overwrite the usual value if we're doing Lynx. */
252b5132
RH
2833 *magicp = LYNXCOFFMAGIC;
2834#endif
b34976b6 2835 return TRUE;
252b5132
RH
2836#endif
2837
2838#ifdef H8500MAGIC
2839 case bfd_arch_h8500:
2840 *magicp = H8500MAGIC;
b34976b6 2841 return TRUE;
252b5132
RH
2842 break;
2843#endif
7920ce38 2844
252b5132
RH
2845#ifdef WE32KMAGIC
2846 case bfd_arch_we32k:
2847 *magicp = WE32KMAGIC;
b34976b6 2848 return TRUE;
252b5132
RH
2849#endif
2850
7f6d05e8 2851#ifdef RS6000COFF_C
252b5132
RH
2852 case bfd_arch_rs6000:
2853#ifndef PPCMAGIC
2854 case bfd_arch_powerpc:
2855#endif
eb1e0e80
NC
2856 BFD_ASSERT (bfd_get_flavour (abfd) == bfd_target_xcoff_flavour);
2857 *magicp = bfd_xcoff_magic_number (abfd);
b34976b6 2858 return TRUE;
252b5132
RH
2859#endif
2860
2861#ifdef MCOREMAGIC
2862 case bfd_arch_mcore:
2863 * magicp = MCOREMAGIC;
b34976b6 2864 return TRUE;
252b5132 2865#endif
e60b52c6 2866
371e71b8
NC
2867#ifdef W65MAGIC
2868 case bfd_arch_w65:
2869 *magicp = W65MAGIC;
b34976b6 2870 return TRUE;
371e71b8
NC
2871#endif
2872
3b16e843
NC
2873#ifdef OR32_MAGIC_BIG
2874 case bfd_arch_or32:
2875 if (bfd_big_endian (abfd))
2876 * magicp = OR32_MAGIC_BIG;
2877 else
2878 * magicp = OR32_MAGIC_LITTLE;
b34976b6 2879 return TRUE;
3b16e843
NC
2880#endif
2881
7499d566
NC
2882#ifdef MAXQ20MAGIC
2883 case bfd_arch_maxq:
5c4504f7
NC
2884 * magicp = MAXQ20MAGIC;
2885 switch (bfd_get_mach (abfd))
2886 {
7920ce38
NC
2887 case bfd_mach_maxq10: * flagsp = F_MAXQ10; return TRUE;
2888 case bfd_mach_maxq20: * flagsp = F_MAXQ20; return TRUE;
2889 default: return FALSE;
5c4504f7 2890 }
7499d566
NC
2891#endif
2892
371e71b8 2893 default: /* Unknown architecture. */
b34976b6 2894 /* Fall through to "return FALSE" below, to avoid
371e71b8 2895 "statement never reached" errors on the one below. */
252b5132
RH
2896 break;
2897 }
2898
b34976b6 2899 return FALSE;
252b5132
RH
2900}
2901
b34976b6 2902static bfd_boolean
7920ce38
NC
2903coff_set_arch_mach (bfd * abfd,
2904 enum bfd_architecture arch,
2905 unsigned long machine)
252b5132
RH
2906{
2907 unsigned dummy1;
2908 unsigned short dummy2;
2909
2910 if (! bfd_default_set_arch_mach (abfd, arch, machine))
b34976b6 2911 return FALSE;
252b5132 2912
82e51918
AM
2913 if (arch != bfd_arch_unknown
2914 && ! coff_set_flags (abfd, &dummy1, &dummy2))
7920ce38 2915 return FALSE; /* We can't represent this type. */
252b5132 2916
7920ce38 2917 return TRUE; /* We're easy... */
252b5132
RH
2918}
2919
75cc7189
ILT
2920#ifdef COFF_IMAGE_WITH_PE
2921
2922/* This is used to sort sections by VMA, as required by PE image
2923 files. */
2924
75cc7189 2925static int
7920ce38 2926sort_by_secaddr (const void * arg1, const void * arg2)
75cc7189
ILT
2927{
2928 const asection *a = *(const asection **) arg1;
2929 const asection *b = *(const asection **) arg2;
2930
2931 if (a->vma < b->vma)
2932 return -1;
2933 else if (a->vma > b->vma)
2934 return 1;
7920ce38
NC
2935
2936 return 0;
75cc7189
ILT
2937}
2938
2939#endif /* COFF_IMAGE_WITH_PE */
252b5132 2940
e60b52c6 2941/* Calculate the file position for each section. */
252b5132
RH
2942
2943#ifndef I960
2944#define ALIGN_SECTIONS_IN_FILE
2945#endif
81635ce4 2946#if defined(TIC80COFF) || defined(TICOFF)
252b5132
RH
2947#undef ALIGN_SECTIONS_IN_FILE
2948#endif
2949
b34976b6 2950static bfd_boolean
7920ce38 2951coff_compute_section_file_positions (bfd * abfd)
252b5132
RH
2952{
2953 asection *current;
7920ce38 2954 asection *previous = NULL;
6b3b007b 2955 file_ptr sofar = bfd_coff_filhsz (abfd);
b34976b6 2956 bfd_boolean align_adjust;
252b5132
RH
2957#ifdef ALIGN_SECTIONS_IN_FILE
2958 file_ptr old_sofar;
2959#endif
2960
2961#ifdef RS6000COFF_C
2962 /* On XCOFF, if we have symbols, set up the .debug section. */
2963 if (bfd_get_symcount (abfd) > 0)
2964 {
2965 bfd_size_type sz;
2966 bfd_size_type i, symcount;
2967 asymbol **symp;
2968
2969 sz = 0;
2970 symcount = bfd_get_symcount (abfd);
2971 for (symp = abfd->outsymbols, i = 0; i < symcount; symp++, i++)
2972 {
2973 coff_symbol_type *cf;
2974
2975 cf = coff_symbol_from (abfd, *symp);
2976 if (cf != NULL
2977 && cf->native != NULL
2978 && SYMNAME_IN_DEBUG (&cf->native->u.syment))
2979 {
2980 size_t len;
2981
2982 len = strlen (bfd_asymbol_name (*symp));
7f6d05e8
CP
2983 if (len > SYMNMLEN || bfd_coff_force_symnames_in_strings (abfd))
2984 sz += len + 1 + bfd_coff_debug_string_prefix_length (abfd);
252b5132
RH
2985 }
2986 }
2987 if (sz > 0)
2988 {
2989 asection *dsec;
2990
8a7140c3 2991 dsec = bfd_make_section_old_way (abfd, DOT_DEBUG);
252b5132
RH
2992 if (dsec == NULL)
2993 abort ();
eea6121a 2994 dsec->size = sz;
252b5132
RH
2995 dsec->flags |= SEC_HAS_CONTENTS;
2996 }
2997 }
2998#endif
2999
3000#ifdef COFF_IMAGE_WITH_PE
3001 int page_size;
7920ce38 3002
e60b52c6 3003 if (coff_data (abfd)->link_info)
252b5132
RH
3004 {
3005 page_size = pe_data (abfd)->pe_opthdr.FileAlignment;
771e446b
NC
3006
3007 /* If no file alignment has been set, default to one.
3008 This repairs 'ld -r' for arm-wince-pe target. */
3009 if (page_size == 0)
3010 page_size = 1;
252b5132
RH
3011 }
3012 else
3013 page_size = PE_DEF_FILE_ALIGNMENT;
3014#else
3015#ifdef COFF_PAGE_SIZE
3016 int page_size = COFF_PAGE_SIZE;
3017#endif
3018#endif
3019
3020 if (bfd_get_start_address (abfd))
7920ce38
NC
3021 /* A start address may have been added to the original file. In this
3022 case it will need an optional header to record it. */
3023 abfd->flags |= EXEC_P;
252b5132
RH
3024
3025 if (abfd->flags & EXEC_P)
6b3b007b 3026 sofar += bfd_coff_aoutsz (abfd);
252b5132
RH
3027#ifdef RS6000COFF_C
3028 else if (xcoff_data (abfd)->full_aouthdr)
6b3b007b 3029 sofar += bfd_coff_aoutsz (abfd);
252b5132
RH
3030 else
3031 sofar += SMALL_AOUTSZ;
3032#endif
3033
6b3b007b 3034 sofar += abfd->section_count * bfd_coff_scnhsz (abfd);
252b5132
RH
3035
3036#ifdef RS6000COFF_C
3037 /* XCOFF handles overflows in the reloc and line number count fields
3038 by allocating a new section header to hold the correct counts. */
3039 for (current = abfd->sections; current != NULL; current = current->next)
3040 if (current->reloc_count >= 0xffff || current->lineno_count >= 0xffff)
6b3b007b 3041 sofar += bfd_coff_scnhsz (abfd);
252b5132
RH
3042#endif
3043
75cc7189
ILT
3044#ifdef COFF_IMAGE_WITH_PE
3045 {
3046 /* PE requires the sections to be in memory order when listed in
3047 the section headers. It also does not like empty loadable
3048 sections. The sections apparently do not have to be in the
3049 right order in the image file itself, but we do need to get the
3050 target_index values right. */
3051
dc810e39 3052 unsigned int count;
75cc7189 3053 asection **section_list;
dc810e39 3054 unsigned int i;
75cc7189 3055 int target_index;
dc810e39 3056 bfd_size_type amt;
75cc7189
ILT
3057
3058 count = 0;
3059 for (current = abfd->sections; current != NULL; current = current->next)
3060 ++count;
3061
3062 /* We allocate an extra cell to simplify the final loop. */
dc810e39
AM
3063 amt = sizeof (struct asection *) * (count + 1);
3064 section_list = bfd_malloc (amt);
75cc7189 3065 if (section_list == NULL)
b34976b6 3066 return FALSE;
75cc7189
ILT
3067
3068 i = 0;
3069 for (current = abfd->sections; current != NULL; current = current->next)
3070 {
3071 section_list[i] = current;
3072 ++i;
3073 }
3074 section_list[i] = NULL;
3075
3076 qsort (section_list, count, sizeof (asection *), sort_by_secaddr);
3077
3078 /* Rethread the linked list into sorted order; at the same time,
3079 assign target_index values. */
3080 target_index = 1;
5daa8fe7
L
3081 abfd->sections = NULL;
3082 abfd->section_last = NULL;
75cc7189
ILT
3083 for (i = 0; i < count; i++)
3084 {
3085 current = section_list[i];
5daa8fe7 3086 bfd_section_list_append (abfd, current);
75cc7189
ILT
3087
3088 /* Later, if the section has zero size, we'll be throwing it
3089 away, so we don't want to number it now. Note that having
3090 a zero size and having real contents are different
3091 concepts: .bss has no contents, but (usually) non-zero
3092 size. */
eea6121a 3093 if (current->size == 0)
75cc7189
ILT
3094 {
3095 /* Discard. However, it still might have (valid) symbols
3096 in it, so arbitrarily set it to section 1 (indexing is
3097 1-based here; usually .text). __end__ and other
3098 contents of .endsection really have this happen.
3099 FIXME: This seems somewhat dubious. */
3100 current->target_index = 1;
3101 }
3102 else
3103 current->target_index = target_index++;
3104 }
3105
2fca4467 3106 free (section_list);
75cc7189
ILT
3107 }
3108#else /* ! COFF_IMAGE_WITH_PE */
3109 {
3110 /* Set the target_index field. */
3111 int target_index;
3112
3113 target_index = 1;
3114 for (current = abfd->sections; current != NULL; current = current->next)
3115 current->target_index = target_index++;
3116 }
3117#endif /* ! COFF_IMAGE_WITH_PE */
3118
b34976b6 3119 align_adjust = FALSE;
75cc7189 3120 for (current = abfd->sections;
7920ce38 3121 current != NULL;
75cc7189 3122 current = current->next)
252b5132
RH
3123 {
3124#ifdef COFF_IMAGE_WITH_PE
75cc7189
ILT
3125 /* With PE we have to pad each section to be a multiple of its
3126 page size too, and remember both sizes. */
3127 if (coff_section_data (abfd, current) == NULL)
252b5132 3128 {
dc810e39 3129 bfd_size_type amt = sizeof (struct coff_section_tdata);
7920ce38
NC
3130
3131 current->used_by_bfd = bfd_zalloc (abfd, amt);
75cc7189 3132 if (current->used_by_bfd == NULL)
b34976b6 3133 return FALSE;
252b5132 3134 }
75cc7189
ILT
3135 if (pei_section_data (abfd, current) == NULL)
3136 {
dc810e39 3137 bfd_size_type amt = sizeof (struct pei_section_tdata);
7920ce38
NC
3138
3139 coff_section_data (abfd, current)->tdata = bfd_zalloc (abfd, amt);
75cc7189 3140 if (coff_section_data (abfd, current)->tdata == NULL)
b34976b6 3141 return FALSE;
75cc7189
ILT
3142 }
3143 if (pei_section_data (abfd, current)->virt_size == 0)
eea6121a 3144 pei_section_data (abfd, current)->virt_size = current->size;
252b5132
RH
3145#endif
3146
75cc7189 3147 /* Only deal with sections which have contents. */
252b5132
RH
3148 if (!(current->flags & SEC_HAS_CONTENTS))
3149 continue;
3150
75cc7189
ILT
3151#ifdef COFF_IMAGE_WITH_PE
3152 /* Make sure we skip empty sections in a PE image. */
eea6121a 3153 if (current->size == 0)
75cc7189
ILT
3154 continue;
3155#endif
3156
252b5132
RH
3157 /* Align the sections in the file to the same boundary on
3158 which they are aligned in virtual memory. I960 doesn't
3159 do this (FIXME) so we can stay in sync with Intel. 960
e60b52c6 3160 doesn't yet page from files... */
252b5132
RH
3161#ifdef ALIGN_SECTIONS_IN_FILE
3162 if ((abfd->flags & EXEC_P) != 0)
3163 {
ed781d5d
NC
3164 /* Make sure this section is aligned on the right boundary - by
3165 padding the previous section up if necessary. */
252b5132 3166 old_sofar = sofar;
7920ce38 3167
47ede03a
TR
3168#ifdef RS6000COFF_C
3169 /* AIX loader checks the text section alignment of (vma - filepos)
3170 So even though the filepos may be aligned wrt the o_algntext, for
19852a2a 3171 AIX executables, this check fails. This shows up when a native
47ede03a
TR
3172 AIX executable is stripped with gnu strip because the default vma
3173 of native is 0x10000150 but default for gnu is 0x10000140. Gnu
b34976b6 3174 stripped gnu excutable passes this check because the filepos is
f3813499
TR
3175 0x0140. This problem also show up with 64 bit shared objects. The
3176 data section must also be aligned. */
b34976b6
AM
3177 if (!strcmp (current->name, _TEXT)
3178 || !strcmp (current->name, _DATA))
47ede03a
TR
3179 {
3180 bfd_vma pad;
3181 bfd_vma align;
3182
3183 sofar = BFD_ALIGN (sofar, 1 << current->alignment_power);
3184
3185 align = 1 << current->alignment_power;
3186 pad = abs (current->vma - sofar) % align;
b34976b6
AM
3187
3188 if (pad)
47ede03a
TR
3189 {
3190 pad = align - pad;
3191 sofar += pad;
3192 }
3193 }
3194 else
3195#else
3196 {
3197 sofar = BFD_ALIGN (sofar, 1 << current->alignment_power);
3198 }
3199#endif
7920ce38 3200 if (previous != NULL)
eea6121a 3201 previous->size += sofar - old_sofar;
252b5132
RH
3202 }
3203
3204#endif
3205
3206 /* In demand paged files the low order bits of the file offset
3207 must match the low order bits of the virtual address. */
3208#ifdef COFF_PAGE_SIZE
3209 if ((abfd->flags & D_PAGED) != 0
3210 && (current->flags & SEC_ALLOC) != 0)
7bf6dede 3211 sofar += (current->vma - (bfd_vma) sofar) % page_size;
252b5132
RH
3212#endif
3213 current->filepos = sofar;
3214
3215#ifdef COFF_IMAGE_WITH_PE
75cc7189 3216 /* Set the padded size. */
eea6121a 3217 current->size = (current->size + page_size -1) & -page_size;
252b5132
RH
3218#endif
3219
eea6121a 3220 sofar += current->size;
252b5132
RH
3221
3222#ifdef ALIGN_SECTIONS_IN_FILE
ed781d5d 3223 /* Make sure that this section is of the right size too. */
252b5132
RH
3224 if ((abfd->flags & EXEC_P) == 0)
3225 {
3226 bfd_size_type old_size;
3227
eea6121a
AM
3228 old_size = current->size;
3229 current->size = BFD_ALIGN (current->size,
3230 1 << current->alignment_power);
3231 align_adjust = current->size != old_size;
3232 sofar += current->size - old_size;
252b5132
RH
3233 }
3234 else
3235 {
3236 old_sofar = sofar;
3237 sofar = BFD_ALIGN (sofar, 1 << current->alignment_power);
3238 align_adjust = sofar != old_sofar;
eea6121a 3239 current->size += sofar - old_sofar;
252b5132
RH
3240 }
3241#endif
3242
3243#ifdef COFF_IMAGE_WITH_PE
3244 /* For PE we need to make sure we pad out to the aligned
eea6121a
AM
3245 size, in case the caller only writes out data to the
3246 unaligned size. */
3247 if (pei_section_data (abfd, current)->virt_size < current->size)
b34976b6 3248 align_adjust = TRUE;
252b5132
RH
3249#endif
3250
3251#ifdef _LIB
3252 /* Force .lib sections to start at zero. The vma is then
3253 incremented in coff_set_section_contents. This is right for
3254 SVR3.2. */
3255 if (strcmp (current->name, _LIB) == 0)
3256 bfd_set_section_vma (abfd, current, 0);
3257#endif
3258
3259 previous = current;
3260 }
3261
3262 /* It is now safe to write to the output file. If we needed an
3263 alignment adjustment for the last section, then make sure that
3264 there is a byte at offset sofar. If there are no symbols and no
3265 relocs, then nothing follows the last section. If we don't force
3266 the last byte out, then the file may appear to be truncated. */
3267 if (align_adjust)
3268 {
3269 bfd_byte b;
3270
3271 b = 0;
3272 if (bfd_seek (abfd, sofar - 1, SEEK_SET) != 0
dc810e39 3273 || bfd_bwrite (&b, (bfd_size_type) 1, abfd) != 1)
b34976b6 3274 return FALSE;
252b5132
RH
3275 }
3276
3277 /* Make sure the relocations are aligned. We don't need to make
3278 sure that this byte exists, because it will only matter if there
3279 really are relocs. */
3280 sofar = BFD_ALIGN (sofar, 1 << COFF_DEFAULT_SECTION_ALIGNMENT_POWER);
3281
3282 obj_relocbase (abfd) = sofar;
b34976b6 3283 abfd->output_has_begun = TRUE;
252b5132 3284
b34976b6 3285 return TRUE;
252b5132
RH
3286}
3287
05793179
NC
3288#ifdef COFF_IMAGE_WITH_PE
3289
3290static unsigned int pelength;
3291static unsigned int peheader;
3292
b34976b6 3293static bfd_boolean
7920ce38 3294coff_read_word (bfd *abfd, unsigned int *value)
05793179
NC
3295{
3296 unsigned char b[2];
3297 int status;
3298
3299 status = bfd_bread (b, (bfd_size_type) 2, abfd);
3300 if (status < 1)
3301 {
3302 *value = 0;
b34976b6 3303 return FALSE;
05793179
NC
3304 }
3305
3306 if (status == 1)
3307 *value = (unsigned int) b[0];
3308 else
3309 *value = (unsigned int) (b[0] + (b[1] << 8));
3310
3311 pelength += (unsigned int) status;
3312
b34976b6 3313 return TRUE;
05793179
NC
3314}
3315
3316static unsigned int
7920ce38 3317coff_compute_checksum (bfd *abfd)
05793179 3318{
b34976b6 3319 bfd_boolean more_data;
05793179
NC
3320 file_ptr filepos;
3321 unsigned int value;
3322 unsigned int total;
3323
3324 total = 0;
3325 pelength = 0;
3326 filepos = (file_ptr) 0;
3327
3328 do
3329 {
3330 if (bfd_seek (abfd, filepos, SEEK_SET) != 0)
3331 return 0;
3332
3333 more_data = coff_read_word (abfd, &value);
3334 total += value;
3335 total = 0xffff & (total + (total >> 0x10));
3336 filepos += 2;
3337 }
3338 while (more_data);
3339
3340 return (0xffff & (total + (total >> 0x10)));
3341}
3342
b34976b6 3343static bfd_boolean
7920ce38 3344coff_apply_checksum (bfd *abfd)
05793179
NC
3345{
3346 unsigned int computed;
3347 unsigned int checksum = 0;
3348
3349 if (bfd_seek (abfd, 0x3c, SEEK_SET) != 0)
b34976b6 3350 return FALSE;
05793179
NC
3351
3352 if (!coff_read_word (abfd, &peheader))
b34976b6 3353 return FALSE;
05793179
NC
3354
3355 if (bfd_seek (abfd, peheader + 0x58, SEEK_SET) != 0)
b34976b6 3356 return FALSE;
05793179
NC
3357
3358 checksum = 0;
3359 bfd_bwrite (&checksum, (bfd_size_type) 4, abfd);
3360
3361 if (bfd_seek (abfd, peheader, SEEK_SET) != 0)
b34976b6 3362 return FALSE;
05793179
NC
3363
3364 computed = coff_compute_checksum (abfd);
3365
3366 checksum = computed + pelength;
3367
3368 if (bfd_seek (abfd, peheader + 0x58, SEEK_SET) != 0)
b34976b6 3369 return FALSE;
05793179
NC
3370
3371 bfd_bwrite (&checksum, (bfd_size_type) 4, abfd);
3372
b34976b6 3373 return TRUE;
05793179
NC
3374}
3375
3376#endif /* COFF_IMAGE_WITH_PE */
3377
b34976b6 3378static bfd_boolean
7920ce38 3379coff_write_object_contents (bfd * abfd)
252b5132
RH
3380{
3381 asection *current;
b34976b6
AM
3382 bfd_boolean hasrelocs = FALSE;
3383 bfd_boolean haslinno = FALSE;
3384 bfd_boolean hasdebug = FALSE;
252b5132
RH
3385 file_ptr scn_base;
3386 file_ptr reloc_base;
3387 file_ptr lineno_base;
3388 file_ptr sym_base;
3e4554a2 3389 unsigned long reloc_size = 0, reloc_count = 0;
252b5132 3390 unsigned long lnno_size = 0;
b34976b6 3391 bfd_boolean long_section_names;
252b5132
RH
3392 asection *text_sec = NULL;
3393 asection *data_sec = NULL;
3394 asection *bss_sec = NULL;
3395 struct internal_filehdr internal_f;
3396 struct internal_aouthdr internal_a;
3397#ifdef COFF_LONG_SECTION_NAMES
3398 size_t string_size = STRING_SIZE_SIZE;
3399#endif
3400
3401 bfd_set_error (bfd_error_system_call);
3402
3403 /* Make a pass through the symbol table to count line number entries and
ed781d5d 3404 put them into the correct asections. */
6b3b007b 3405 lnno_size = coff_count_linenumbers (abfd) * bfd_coff_linesz (abfd);
252b5132 3406
82e51918 3407 if (! abfd->output_has_begun)
252b5132
RH
3408 {
3409 if (! coff_compute_section_file_positions (abfd))
b34976b6 3410 return FALSE;
252b5132
RH
3411 }
3412
3413 reloc_base = obj_relocbase (abfd);
3414
ed781d5d 3415 /* Work out the size of the reloc and linno areas. */
252b5132
RH
3416
3417 for (current = abfd->sections; current != NULL; current =
3418 current->next)
3e4554a2
DD
3419 {
3420#ifdef COFF_WITH_PE
ed781d5d 3421 /* We store the actual reloc count in the first reloc's addr. */
e9168c1e 3422 if (obj_pe (abfd) && current->reloc_count >= 0xffff)
3e4554a2
DD
3423 reloc_count ++;
3424#endif
3425 reloc_count += current->reloc_count;
3426 }
3427
3428 reloc_size = reloc_count * bfd_coff_relsz (abfd);
252b5132
RH
3429
3430 lineno_base = reloc_base + reloc_size;
3431 sym_base = lineno_base + lnno_size;
3432
ed781d5d 3433 /* Indicate in each section->line_filepos its actual file address. */
252b5132
RH
3434 for (current = abfd->sections; current != NULL; current =
3435 current->next)
3436 {
3437 if (current->lineno_count)
3438 {
3439 current->line_filepos = lineno_base;
3440 current->moving_line_filepos = lineno_base;
6b3b007b 3441 lineno_base += current->lineno_count * bfd_coff_linesz (abfd);
252b5132
RH
3442 }
3443 else
7920ce38
NC
3444 current->line_filepos = 0;
3445
252b5132
RH
3446 if (current->reloc_count)
3447 {
3448 current->rel_filepos = reloc_base;
6b3b007b 3449 reloc_base += current->reloc_count * bfd_coff_relsz (abfd);
3e4554a2 3450#ifdef COFF_WITH_PE
ed781d5d 3451 /* Extra reloc to hold real count. */
e9168c1e 3452 if (obj_pe (abfd) && current->reloc_count >= 0xffff)
3e4554a2
DD
3453 reloc_base += bfd_coff_relsz (abfd);
3454#endif
252b5132
RH
3455 }
3456 else
7920ce38 3457 current->rel_filepos = 0;
252b5132
RH
3458 }
3459
3460 /* Write section headers to the file. */
3461 internal_f.f_nscns = 0;
3462
3463 if ((abfd->flags & EXEC_P) != 0)
6b3b007b 3464 scn_base = bfd_coff_filhsz (abfd) + bfd_coff_aoutsz (abfd);
252b5132
RH
3465 else
3466 {
6b3b007b 3467 scn_base = bfd_coff_filhsz (abfd);
252b5132 3468#ifdef RS6000COFF_C
dc810e39 3469#ifndef XCOFF64
252b5132 3470 if (xcoff_data (abfd)->full_aouthdr)
6b3b007b 3471 scn_base += bfd_coff_aoutsz (abfd);
252b5132
RH
3472 else
3473 scn_base += SMALL_AOUTSZ;
dc810e39 3474#endif
252b5132
RH
3475#endif
3476 }
3477
3478 if (bfd_seek (abfd, scn_base, SEEK_SET) != 0)
b34976b6 3479 return FALSE;
252b5132 3480
b34976b6 3481 long_section_names = FALSE;
252b5132
RH
3482 for (current = abfd->sections;
3483 current != NULL;
3484 current = current->next)
3485 {
3486 struct internal_scnhdr section;
b34976b6 3487 bfd_boolean is_reloc_section = FALSE;
252b5132
RH
3488
3489#ifdef COFF_IMAGE_WITH_PE
3490 if (strcmp (current->name, ".reloc") == 0)
3491 {
b34976b6
AM
3492 is_reloc_section = TRUE;
3493 hasrelocs = TRUE;
252b5132
RH
3494 pe_data (abfd)->has_reloc_section = 1;
3495 }
3496#endif
3497
252b5132
RH
3498 internal_f.f_nscns++;
3499
3500 strncpy (section.s_name, current->name, SCNNMLEN);
3501
3502#ifdef COFF_LONG_SECTION_NAMES
3503 /* Handle long section names as in PE. This must be compatible
00692651 3504 with the code in coff_write_symbols and _bfd_coff_final_link. */
252b5132
RH
3505 {
3506 size_t len;
3507
3508 len = strlen (current->name);
3509 if (len > SCNNMLEN)
3510 {
3511 memset (section.s_name, 0, SCNNMLEN);
3512 sprintf (section.s_name, "/%lu", (unsigned long) string_size);
3513 string_size += len + 1;
b34976b6 3514 long_section_names = TRUE;
252b5132
RH
3515 }
3516 }
3517#endif
3518
3519#ifdef _LIB
3520 /* Always set s_vaddr of .lib to 0. This is right for SVR3.2
3521 Ian Taylor <ian@cygnus.com>. */
3522 if (strcmp (current->name, _LIB) == 0)
3523 section.s_vaddr = 0;
3524 else
3525#endif
3526 section.s_vaddr = current->vma;
3527 section.s_paddr = current->lma;
eea6121a 3528 section.s_size = current->size;
b9af77f5 3529#ifdef coff_get_section_load_page
e60b52c6 3530 section.s_page = coff_get_section_load_page (current);
b9af77f5 3531#endif
252b5132
RH
3532
3533#ifdef COFF_WITH_PE
3534 section.s_paddr = 0;
3535#endif
3536#ifdef COFF_IMAGE_WITH_PE
3537 /* Reminder: s_paddr holds the virtual size of the section. */
3538 if (coff_section_data (abfd, current) != NULL
3539 && pei_section_data (abfd, current) != NULL)
3540 section.s_paddr = pei_section_data (abfd, current)->virt_size;
3541 else
3542 section.s_paddr = 0;
3543#endif
3544
ed781d5d
NC
3545 /* If this section has no size or is unloadable then the scnptr
3546 will be 0 too. */
eea6121a
AM
3547 if (current->size == 0
3548 || (current->flags & (SEC_LOAD | SEC_HAS_CONTENTS)) == 0)
ed781d5d 3549 section.s_scnptr = 0;
252b5132 3550 else
ed781d5d
NC
3551 section.s_scnptr = current->filepos;
3552
252b5132
RH
3553 section.s_relptr = current->rel_filepos;
3554 section.s_lnnoptr = current->line_filepos;
3555 section.s_nreloc = current->reloc_count;
3556 section.s_nlnno = current->lineno_count;
79207490
ILT
3557#ifndef COFF_IMAGE_WITH_PE
3558 /* In PEI, relocs come in the .reloc section. */
252b5132 3559 if (current->reloc_count != 0)
b34976b6 3560 hasrelocs = TRUE;
79207490 3561#endif
252b5132 3562 if (current->lineno_count != 0)
b34976b6 3563 haslinno = TRUE;
4cfec37b
ILT
3564 if ((current->flags & SEC_DEBUGGING) != 0
3565 && ! is_reloc_section)
b34976b6 3566 hasdebug = TRUE;
252b5132 3567
60bcf0fa 3568#ifdef RS6000COFF_C
7f6d05e8 3569#ifndef XCOFF64
252b5132
RH
3570 /* Indicate the use of an XCOFF overflow section header. */
3571 if (current->reloc_count >= 0xffff || current->lineno_count >= 0xffff)
3572 {
3573 section.s_nreloc = 0xffff;
3574 section.s_nlnno = 0xffff;
3575 }
7f6d05e8 3576#endif
252b5132
RH
3577#endif
3578
3579 section.s_flags = sec_to_styp_flags (current->name, current->flags);
3580
3581 if (!strcmp (current->name, _TEXT))
ed781d5d 3582 text_sec = current;
252b5132 3583 else if (!strcmp (current->name, _DATA))
ed781d5d 3584 data_sec = current;
252b5132 3585 else if (!strcmp (current->name, _BSS))
ed781d5d 3586 bss_sec = current;
252b5132
RH
3587
3588#ifdef I960
3589 section.s_align = (current->alignment_power
3590 ? 1 << current->alignment_power
3591 : 0);
81635ce4 3592#endif
e60b52c6 3593#ifdef TIC80COFF
ed781d5d 3594 /* TI COFF puts the alignment power in bits 8-11 of the flags. */
252b5132
RH
3595 section.s_flags |= (current->alignment_power & 0xF) << 8;
3596#endif
81635ce4
TW
3597#ifdef COFF_ENCODE_ALIGNMENT
3598 COFF_ENCODE_ALIGNMENT(section, current->alignment_power);
252b5132
RH
3599#endif
3600
3601#ifdef COFF_IMAGE_WITH_PE
00692651
ILT
3602 /* Suppress output of the sections if they are null. ld
3603 includes the bss and data sections even if there is no size
3604 assigned to them. NT loader doesn't like it if these section
3605 headers are included if the sections themselves are not
3606 needed. See also coff_compute_section_file_positions. */
252b5132
RH
3607 if (section.s_size == 0)
3608 internal_f.f_nscns--;
3609 else
3610#endif
3611 {
3612 SCNHDR buff;
dc810e39
AM
3613 bfd_size_type amt = bfd_coff_scnhsz (abfd);
3614
252b5132 3615 if (coff_swap_scnhdr_out (abfd, &section, &buff) == 0
7920ce38 3616 || bfd_bwrite (& buff, amt, abfd) != amt)
b34976b6 3617 return FALSE;
252b5132
RH
3618 }
3619
3620#ifdef COFF_WITH_PE
3621 /* PE stores COMDAT section information in the symbol table. If
3622 this section is supposed to have some COMDAT info, track down
3623 the symbol in the symbol table and modify it. */
3624 if ((current->flags & SEC_LINK_ONCE) != 0)
3625 {
3626 unsigned int i, count;
3627 asymbol **psym;
3628 coff_symbol_type *csym = NULL;
3629 asymbol **psymsec;
3630
3631 psymsec = NULL;
3632 count = bfd_get_symcount (abfd);
3633 for (i = 0, psym = abfd->outsymbols; i < count; i++, psym++)
3634 {
3635 if ((*psym)->section != current)
3636 continue;
3637
3638 /* Remember the location of the first symbol in this
3639 section. */
3640 if (psymsec == NULL)
3641 psymsec = psym;
3642
3643 /* See if this is the section symbol. */
3644 if (strcmp ((*psym)->name, current->name) == 0)
3645 {
3646 csym = coff_symbol_from (abfd, *psym);
3647 if (csym == NULL
3648 || csym->native == NULL
3649 || csym->native->u.syment.n_numaux < 1
3650 || csym->native->u.syment.n_sclass != C_STAT
3651 || csym->native->u.syment.n_type != T_NULL)
3652 continue;
3653
3654 /* Here *PSYM is the section symbol for CURRENT. */
3655
3656 break;
3657 }
3658 }
3659
3660 /* Did we find it?
3661 Note that we might not if we're converting the file from
3662 some other object file format. */
3663 if (i < count)
3664 {
3665 combined_entry_type *aux;
3666
3667 /* We don't touch the x_checksum field. The
3668 x_associated field is not currently supported. */
3669
3670 aux = csym->native + 1;
3671 switch (current->flags & SEC_LINK_DUPLICATES)
3672 {
3673 case SEC_LINK_DUPLICATES_DISCARD:
3674 aux->u.auxent.x_scn.x_comdat = IMAGE_COMDAT_SELECT_ANY;
3675 break;
3676
3677 case SEC_LINK_DUPLICATES_ONE_ONLY:
3678 aux->u.auxent.x_scn.x_comdat =
3679 IMAGE_COMDAT_SELECT_NODUPLICATES;
3680 break;
3681
3682 case SEC_LINK_DUPLICATES_SAME_SIZE:
3683 aux->u.auxent.x_scn.x_comdat =
3684 IMAGE_COMDAT_SELECT_SAME_SIZE;
3685 break;
3686
3687 case SEC_LINK_DUPLICATES_SAME_CONTENTS:
3688 aux->u.auxent.x_scn.x_comdat =
3689 IMAGE_COMDAT_SELECT_EXACT_MATCH;
3690 break;
3691 }
3692
3693 /* The COMDAT symbol must be the first symbol from this
3694 section in the symbol table. In order to make this
3695 work, we move the COMDAT symbol before the first
3696 symbol we found in the search above. It's OK to
3697 rearrange the symbol table at this point, because
3698 coff_renumber_symbols is going to rearrange it
3699 further and fix up all the aux entries. */
3700 if (psym != psymsec)
3701 {
3702 asymbol *hold;
3703 asymbol **pcopy;
3704
3705 hold = *psym;
3706 for (pcopy = psym; pcopy > psymsec; pcopy--)
3707 pcopy[0] = pcopy[-1];
3708 *psymsec = hold;
3709 }
3710 }
3711 }
3712#endif /* COFF_WITH_PE */
3713 }
3714
3715#ifdef RS6000COFF_C
dc810e39 3716#ifndef XCOFF64
252b5132
RH
3717 /* XCOFF handles overflows in the reloc and line number count fields
3718 by creating a new section header to hold the correct values. */
3719 for (current = abfd->sections; current != NULL; current = current->next)
3720 {
3721 if (current->reloc_count >= 0xffff || current->lineno_count >= 0xffff)
3722 {
3723 struct internal_scnhdr scnhdr;
3724 SCNHDR buff;
dc810e39 3725 bfd_size_type amt;
252b5132
RH
3726
3727 internal_f.f_nscns++;
3728 strncpy (&(scnhdr.s_name[0]), current->name, 8);
3729 scnhdr.s_paddr = current->reloc_count;
3730 scnhdr.s_vaddr = current->lineno_count;
3731 scnhdr.s_size = 0;
3732 scnhdr.s_scnptr = 0;
3733 scnhdr.s_relptr = current->rel_filepos;
3734 scnhdr.s_lnnoptr = current->line_filepos;
3735 scnhdr.s_nreloc = current->target_index;
3736 scnhdr.s_nlnno = current->target_index;
3737 scnhdr.s_flags = STYP_OVRFLO;
dc810e39 3738 amt = bfd_coff_scnhsz (abfd);
252b5132 3739 if (coff_swap_scnhdr_out (abfd, &scnhdr, &buff) == 0
7920ce38 3740 || bfd_bwrite (& buff, amt, abfd) != amt)
b34976b6 3741 return FALSE;
252b5132
RH
3742 }
3743 }
beb1bf64 3744#endif
252b5132
RH
3745#endif
3746
e60b52c6 3747 /* OK, now set up the filehdr... */
252b5132
RH
3748
3749 /* Don't include the internal abs section in the section count */
3750
ed781d5d 3751 /* We will NOT put a fucking timestamp in the header here. Every time you
252b5132
RH
3752 put it back, I will come in and take it out again. I'm sorry. This
3753 field does not belong here. We fill it with a 0 so it compares the
ed781d5d 3754 same but is not a reasonable time. -- gnu@cygnus.com */
252b5132 3755 internal_f.f_timdat = 0;
252b5132
RH
3756 internal_f.f_flags = 0;
3757
3758 if (abfd->flags & EXEC_P)
6b3b007b 3759 internal_f.f_opthdr = bfd_coff_aoutsz (abfd);
252b5132
RH
3760 else
3761 {
3762 internal_f.f_opthdr = 0;
3763#ifdef RS6000COFF_C
dc810e39 3764#ifndef XCOFF64
252b5132 3765 if (xcoff_data (abfd)->full_aouthdr)
6b3b007b 3766 internal_f.f_opthdr = bfd_coff_aoutsz (abfd);
252b5132
RH
3767 else
3768 internal_f.f_opthdr = SMALL_AOUTSZ;
dc810e39 3769#endif
252b5132
RH
3770#endif
3771 }
3772
3773 if (!hasrelocs)
3774 internal_f.f_flags |= F_RELFLG;
3775 if (!haslinno)
3776 internal_f.f_flags |= F_LNNO;
3777 if (abfd->flags & EXEC_P)
3778 internal_f.f_flags |= F_EXEC;
4cfec37b
ILT
3779#ifdef COFF_IMAGE_WITH_PE
3780 if (! hasdebug)
3781 internal_f.f_flags |= IMAGE_FILE_DEBUG_STRIPPED;
d70270c5
BF
3782 if (pe_data (abfd)->real_flags & IMAGE_FILE_LARGE_ADDRESS_AWARE)
3783 internal_f.f_flags |= IMAGE_FILE_LARGE_ADDRESS_AWARE;
4cfec37b 3784#endif
252b5132 3785
99ad8390 3786#ifndef COFF_WITH_pex64
bcb9b88d
NC
3787#ifdef COFF_WITH_PE
3788 internal_f.f_flags |= IMAGE_FILE_32BIT_MACHINE;
3789#else
252b5132
RH
3790 if (bfd_little_endian (abfd))
3791 internal_f.f_flags |= F_AR32WR;
3792 else
3793 internal_f.f_flags |= F_AR32W;
8a1ad8e7 3794#endif
99ad8390 3795#endif
252b5132 3796
81635ce4 3797#ifdef TI_TARGET_ID
ed781d5d
NC
3798 /* Target id is used in TI COFF v1 and later; COFF0 won't use this field,
3799 but it doesn't hurt to set it internally. */
81635ce4
TW
3800 internal_f.f_target_id = TI_TARGET_ID;
3801#endif
252b5132
RH
3802#ifdef TIC80_TARGET_ID
3803 internal_f.f_target_id = TIC80_TARGET_ID;
3804#endif
3805
ed781d5d
NC
3806 /* FIXME, should do something about the other byte orders and
3807 architectures. */
252b5132
RH
3808
3809#ifdef RS6000COFF_C
3810 if ((abfd->flags & DYNAMIC) != 0)
3811 internal_f.f_flags |= F_SHROBJ;
3812 if (bfd_get_section_by_name (abfd, _LOADER) != NULL)
3813 internal_f.f_flags |= F_DYNLOAD;
3814#endif
3815
3816 memset (&internal_a, 0, sizeof internal_a);
3817
ed781d5d 3818 /* Set up architecture-dependent stuff. */
252b5132
RH
3819 {
3820 unsigned int magic = 0;
3821 unsigned short flags = 0;
ed781d5d 3822
252b5132
RH
3823 coff_set_flags (abfd, &magic, &flags);
3824 internal_f.f_magic = magic;
3825 internal_f.f_flags |= flags;
e60b52c6 3826 /* ...and the "opt"hdr... */
252b5132 3827
81635ce4
TW
3828#ifdef TICOFF_AOUT_MAGIC
3829 internal_a.magic = TICOFF_AOUT_MAGIC;
3830#define __A_MAGIC_SET__
3831#endif
252b5132
RH
3832#ifdef TIC80COFF
3833 internal_a.magic = TIC80_ARCH_MAGIC;
3834#define __A_MAGIC_SET__
3835#endif /* TIC80 */
3836#ifdef I860
3837 /* FIXME: What are the a.out magic numbers for the i860? */
3838 internal_a.magic = 0;
3839#define __A_MAGIC_SET__
3840#endif /* I860 */
3841#ifdef I960
3842 internal_a.magic = (magic == I960ROMAGIC ? NMAGIC : OMAGIC);
3843#define __A_MAGIC_SET__
3844#endif /* I960 */
3845#if M88
3846#define __A_MAGIC_SET__
3847 internal_a.magic = PAGEMAGICBCS;
3848#endif /* M88 */
3849
3850#if APOLLO_M68
3851#define __A_MAGIC_SET__
3852 internal_a.magic = APOLLO_COFF_VERSION_NUMBER;
3853#endif
3854
3855#if defined(M68) || defined(WE32K) || defined(M68K)
3856#define __A_MAGIC_SET__
3857#if defined(LYNXOS)
3858 internal_a.magic = LYNXCOFFMAGIC;
3859#else
3860#if defined(TARG_AUX)
3861 internal_a.magic = (abfd->flags & D_PAGED ? PAGEMAGICPEXECPAGED :
3862 abfd->flags & WP_TEXT ? PAGEMAGICPEXECSWAPPED :
3863 PAGEMAGICEXECSWAPPED);
3864#else
3865#if defined (PAGEMAGICPEXECPAGED)
3866 internal_a.magic = PAGEMAGICPEXECPAGED;
3867#endif
3868#endif /* TARG_AUX */
3869#endif /* LYNXOS */
3870#endif /* M68 || WE32K || M68K */
3871
3872#if defined(ARM)
3873#define __A_MAGIC_SET__
3874 internal_a.magic = ZMAGIC;
e60b52c6 3875#endif
252b5132
RH
3876
3877#if defined(PPC_PE)
3878#define __A_MAGIC_SET__
3879 internal_a.magic = IMAGE_NT_OPTIONAL_HDR_MAGIC;
3880#endif
3881
3882#if defined MCORE_PE
3883#define __A_MAGIC_SET__
3884 internal_a.magic = IMAGE_NT_OPTIONAL_HDR_MAGIC;
e60b52c6 3885#endif
252b5132
RH
3886
3887#if defined(I386)
3888#define __A_MAGIC_SET__
99ad8390 3889#if defined LYNXOS
252b5132 3890 internal_a.magic = LYNXCOFFMAGIC;
99ad8390
NC
3891#elif defined AMD64
3892 internal_a.magic = IMAGE_NT_OPTIONAL_HDR64_MAGIC;
3893#else
252b5132 3894 internal_a.magic = ZMAGIC;
99ad8390 3895#endif
252b5132
RH
3896#endif /* I386 */
3897
fac41780
JW
3898#if defined(IA64)
3899#define __A_MAGIC_SET__
7a2ec0a6 3900 internal_a.magic = PE32PMAGIC;
fac41780
JW
3901#endif /* IA64 */
3902
252b5132
RH
3903#if defined(SPARC)
3904#define __A_MAGIC_SET__
3905#if defined(LYNXOS)
3906 internal_a.magic = LYNXCOFFMAGIC;
3907#endif /* LYNXOS */
3908#endif /* SPARC */
3909
3910#ifdef RS6000COFF_C
3911#define __A_MAGIC_SET__
3912 internal_a.magic = (abfd->flags & D_PAGED) ? RS6K_AOUTHDR_ZMAGIC :
3913 (abfd->flags & WP_TEXT) ? RS6K_AOUTHDR_NMAGIC :
3914 RS6K_AOUTHDR_OMAGIC;
3915#endif
3916
17505c5c
NC
3917#if defined(SH) && defined(COFF_WITH_PE)
3918#define __A_MAGIC_SET__
3919 internal_a.magic = SH_PE_MAGIC;
3920#endif
3921
3922#if defined(MIPS) && defined(COFF_WITH_PE)
3923#define __A_MAGIC_SET__
3924 internal_a.magic = MIPS_PE_MAGIC;
3925#endif
3926
3b16e843
NC
3927#ifdef OR32
3928#define __A_MAGIC_SET__
3929 internal_a.magic = NMAGIC; /* Assume separate i/d. */
3930#endif
3931
7499d566
NC
3932#ifdef MAXQ20MAGIC
3933#define __A_MAGIC_SET__
3934 internal_a.magic = MAXQ20MAGIC;
3935#endif
3936
252b5132
RH
3937#ifndef __A_MAGIC_SET__
3938#include "Your aouthdr magic number is not being set!"
3939#else
3940#undef __A_MAGIC_SET__
3941#endif
3942 }
3943
3944 /* FIXME: Does anybody ever set this to another value? */
3945 internal_a.vstamp = 0;
3946
ed781d5d 3947 /* Now should write relocs, strings, syms. */
252b5132
RH
3948 obj_sym_filepos (abfd) = sym_base;
3949
3950 if (bfd_get_symcount (abfd) != 0)
3951 {
3952 int firstundef;
0e71e495 3953
252b5132 3954 if (!coff_renumber_symbols (abfd, &firstundef))
b34976b6 3955 return FALSE;
252b5132
RH
3956 coff_mangle_symbols (abfd);
3957 if (! coff_write_symbols (abfd))
b34976b6 3958 return FALSE;
252b5132 3959 if (! coff_write_linenumbers (abfd))
b34976b6 3960 return FALSE;
252b5132 3961 if (! coff_write_relocs (abfd, firstundef))
b34976b6 3962 return FALSE;
252b5132
RH
3963 }
3964#ifdef COFF_LONG_SECTION_NAMES
d71f672e 3965 else if (long_section_names && ! obj_coff_strings_written (abfd))
252b5132
RH
3966 {
3967 /* If we have long section names we have to write out the string
3968 table even if there are no symbols. */
3969 if (! coff_write_symbols (abfd))
b34976b6 3970 return FALSE;
252b5132
RH
3971 }
3972#endif
3973#ifdef COFF_IMAGE_WITH_PE
3974#ifdef PPC_PE
3975 else if ((abfd->flags & EXEC_P) != 0)
3976 {
3977 bfd_byte b;
3978
3979 /* PowerPC PE appears to require that all executable files be
3980 rounded up to the page size. */
3981 b = 0;
3982 if (bfd_seek (abfd,
dc810e39 3983 (file_ptr) BFD_ALIGN (sym_base, COFF_PAGE_SIZE) - 1,
252b5132 3984 SEEK_SET) != 0
dc810e39 3985 || bfd_bwrite (&b, (bfd_size_type) 1, abfd) != 1)
b34976b6 3986 return FALSE;
252b5132
RH
3987 }
3988#endif
3989#endif
3990
3991 /* If bfd_get_symcount (abfd) != 0, then we are not using the COFF
3992 backend linker, and obj_raw_syment_count is not valid until after
3993 coff_write_symbols is called. */
3994 if (obj_raw_syment_count (abfd) != 0)
3995 {
3996 internal_f.f_symptr = sym_base;
3997#ifdef RS6000COFF_C
3998 /* AIX appears to require that F_RELFLG not be set if there are
3999 local symbols but no relocations. */
4000 internal_f.f_flags &=~ F_RELFLG;
4001#endif
4002 }
4003 else
4004 {
4005 if (long_section_names)
4006 internal_f.f_symptr = sym_base;
4007 else
4008 internal_f.f_symptr = 0;
4009 internal_f.f_flags |= F_LSYMS;
4010 }
4011
4012 if (text_sec)
4013 {
eea6121a 4014 internal_a.tsize = text_sec->size;
252b5132
RH
4015 internal_a.text_start = internal_a.tsize ? text_sec->vma : 0;
4016 }
4017 if (data_sec)
4018 {
eea6121a 4019 internal_a.dsize = data_sec->size;
252b5132
RH
4020 internal_a.data_start = internal_a.dsize ? data_sec->vma : 0;
4021 }
4022 if (bss_sec)
4023 {
eea6121a 4024 internal_a.bsize = bss_sec->size;
252b5132
RH
4025 if (internal_a.bsize && bss_sec->vma < internal_a.data_start)
4026 internal_a.data_start = bss_sec->vma;
4027 }
4028
4029 internal_a.entry = bfd_get_start_address (abfd);
4030 internal_f.f_nsyms = obj_raw_syment_count (abfd);
4031
4032#ifdef RS6000COFF_C
4033 if (xcoff_data (abfd)->full_aouthdr)
4034 {
4035 bfd_vma toc;
4036 asection *loader_sec;
4037
4038 internal_a.vstamp = 1;
4039
4040 internal_a.o_snentry = xcoff_data (abfd)->snentry;
4041 if (internal_a.o_snentry == 0)
4042 internal_a.entry = (bfd_vma) -1;
4043
4044 if (text_sec != NULL)
4045 {
4046 internal_a.o_sntext = text_sec->target_index;
4047 internal_a.o_algntext = bfd_get_section_alignment (abfd, text_sec);
4048 }
4049 else
4050 {
4051 internal_a.o_sntext = 0;
4052 internal_a.o_algntext = 0;
4053 }
4054 if (data_sec != NULL)
4055 {
4056 internal_a.o_sndata = data_sec->target_index;
4057 internal_a.o_algndata = bfd_get_section_alignment (abfd, data_sec);
4058 }
4059 else
4060 {
4061 internal_a.o_sndata = 0;
4062 internal_a.o_algndata = 0;
4063 }
4064 loader_sec = bfd_get_section_by_name (abfd, ".loader");
4065 if (loader_sec != NULL)
4066 internal_a.o_snloader = loader_sec->target_index;
4067 else
4068 internal_a.o_snloader = 0;
4069 if (bss_sec != NULL)
4070 internal_a.o_snbss = bss_sec->target_index;
4071 else
4072 internal_a.o_snbss = 0;
4073
4074 toc = xcoff_data (abfd)->toc;
4075 internal_a.o_toc = toc;
4076 internal_a.o_sntoc = xcoff_data (abfd)->sntoc;
4077
4078 internal_a.o_modtype = xcoff_data (abfd)->modtype;
4079 if (xcoff_data (abfd)->cputype != -1)
4080 internal_a.o_cputype = xcoff_data (abfd)->cputype;
4081 else
4082 {
4083 switch (bfd_get_arch (abfd))
4084 {
4085 case bfd_arch_rs6000:
4086 internal_a.o_cputype = 4;
4087 break;
4088 case bfd_arch_powerpc:
250d94fd 4089 if (bfd_get_mach (abfd) == bfd_mach_ppc)
252b5132
RH
4090 internal_a.o_cputype = 3;
4091 else
4092 internal_a.o_cputype = 1;
4093 break;
4094 default:
4095 abort ();
4096 }
4097 }
4098 internal_a.o_maxstack = xcoff_data (abfd)->maxstack;
4099 internal_a.o_maxdata = xcoff_data (abfd)->maxdata;
4100 }
4101#endif
4102
7920ce38 4103 /* Now write them. */
252b5132 4104 if (bfd_seek (abfd, (file_ptr) 0, SEEK_SET) != 0)
b34976b6 4105 return FALSE;
e60b52c6 4106
252b5132 4107 {
b5f303f0 4108 char * buff;
dc810e39 4109 bfd_size_type amount = bfd_coff_filhsz (abfd);
e60b52c6 4110
dc810e39 4111 buff = bfd_malloc (amount);
e60b52c6 4112 if (buff == NULL)
b34976b6 4113 return FALSE;
e60b52c6 4114
7920ce38
NC
4115 bfd_coff_swap_filehdr_out (abfd, & internal_f, buff);
4116 amount = bfd_bwrite (buff, amount, abfd);
e60b52c6 4117
2fca4467 4118 free (buff);
e60b52c6 4119
b5f303f0 4120 if (amount != bfd_coff_filhsz (abfd))
b34976b6 4121 return FALSE;
252b5132 4122 }
e60b52c6 4123
252b5132
RH
4124 if (abfd->flags & EXEC_P)
4125 {
e60b52c6 4126 /* Note that peicode.h fills in a PEAOUTHDR, not an AOUTHDR.
ed781d5d 4127 include/coff/pe.h sets AOUTSZ == sizeof (PEAOUTHDR)). */
b5f303f0 4128 char * buff;
dc810e39 4129 bfd_size_type amount = bfd_coff_aoutsz (abfd);
b5f303f0 4130
dc810e39 4131 buff = bfd_malloc (amount);
e60b52c6 4132 if (buff == NULL)
b34976b6 4133 return FALSE;
e60b52c6 4134
7920ce38
NC
4135 coff_swap_aouthdr_out (abfd, & internal_a, buff);
4136 amount = bfd_bwrite (buff, amount, abfd);
e60b52c6 4137
2fca4467 4138 free (buff);
e60b52c6 4139
b5f303f0 4140 if (amount != bfd_coff_aoutsz (abfd))
b34976b6 4141 return FALSE;
05793179
NC
4142
4143#ifdef COFF_IMAGE_WITH_PE
4144 if (! coff_apply_checksum (abfd))
b34976b6 4145 return FALSE;
05793179 4146#endif
252b5132
RH
4147 }
4148#ifdef RS6000COFF_C
4149 else
4150 {
4151 AOUTHDR buff;
4152 size_t size;
4153
4154 /* XCOFF seems to always write at least a small a.out header. */
7920ce38 4155 coff_swap_aouthdr_out (abfd, & internal_a, & buff);
252b5132 4156 if (xcoff_data (abfd)->full_aouthdr)
6b3b007b 4157 size = bfd_coff_aoutsz (abfd);
252b5132
RH
4158 else
4159 size = SMALL_AOUTSZ;
7920ce38 4160 if (bfd_bwrite (& buff, (bfd_size_type) size, abfd) != size)
b34976b6 4161 return FALSE;
252b5132
RH
4162 }
4163#endif
4164
b34976b6 4165 return TRUE;
252b5132
RH
4166}
4167
b34976b6 4168static bfd_boolean
7920ce38
NC
4169coff_set_section_contents (bfd * abfd,
4170 sec_ptr section,
4171 const void * location,
4172 file_ptr offset,
4173 bfd_size_type count)
252b5132 4174{
ed781d5d 4175 if (! abfd->output_has_begun) /* Set by bfd.c handler. */
252b5132
RH
4176 {
4177 if (! coff_compute_section_file_positions (abfd))
b34976b6 4178 return FALSE;
252b5132
RH
4179 }
4180
4181#if defined(_LIB) && !defined(TARG_AUX)
252b5132
RH
4182 /* The physical address field of a .lib section is used to hold the
4183 number of shared libraries in the section. This code counts the
4184 number of sections being written, and increments the lma field
4185 with the number.
4186
4187 I have found no documentation on the contents of this section.
4188 Experimentation indicates that the section contains zero or more
4189 records, each of which has the following structure:
4190
4191 - a (four byte) word holding the length of this record, in words,
4192 - a word that always seems to be set to "2",
4193 - the path to a shared library, null-terminated and then padded
4194 to a whole word boundary.
4195
4196 bfd_assert calls have been added to alert if an attempt is made
4197 to write a section which doesn't follow these assumptions. The
4198 code has been tested on ISC 4.1 by me, and on SCO by Robert Lipe
4199 <robertl@arnet.com> (Thanks!).
e60b52c6 4200
ed781d5d 4201 Gvran Uddeborg <gvran@uddeborg.pp.se>. */
252b5132
RH
4202 if (strcmp (section->name, _LIB) == 0)
4203 {
4204 bfd_byte *rec, *recend;
4205
4206 rec = (bfd_byte *) location;
4207 recend = rec + count;
4208 while (rec < recend)
4209 {
4210 ++section->lma;
4211 rec += bfd_get_32 (abfd, rec) * 4;
4212 }
4213
4214 BFD_ASSERT (rec == recend);
4215 }
252b5132
RH
4216#endif
4217
4218 /* Don't write out bss sections - one way to do this is to
e60b52c6 4219 see if the filepos has not been set. */
252b5132 4220 if (section->filepos == 0)
b34976b6 4221 return TRUE;
252b5132 4222
dc810e39 4223 if (bfd_seek (abfd, section->filepos + offset, SEEK_SET) != 0)
b34976b6 4224 return FALSE;
252b5132 4225
dc810e39 4226 if (count == 0)
b34976b6 4227 return TRUE;
dc810e39
AM
4228
4229 return bfd_bwrite (location, count, abfd) == count;
252b5132 4230}
252b5132 4231
7920ce38
NC
4232static void *
4233buy_and_read (bfd *abfd, file_ptr where, bfd_size_type size)
252b5132 4234{
7920ce38
NC
4235 void * area = bfd_alloc (abfd, size);
4236
252b5132
RH
4237 if (!area)
4238 return (NULL);
dc810e39
AM
4239 if (bfd_seek (abfd, where, SEEK_SET) != 0
4240 || bfd_bread (area, size, abfd) != size)
252b5132
RH
4241 return (NULL);
4242 return (area);
7920ce38 4243}
252b5132
RH
4244
4245/*
4246SUBSUBSECTION
4247 Reading linenumbers
4248
4249 Creating the linenumber table is done by reading in the entire
4250 coff linenumber table, and creating another table for internal use.
4251
4252 A coff linenumber table is structured so that each function
4253 is marked as having a line number of 0. Each line within the
4254 function is an offset from the first line in the function. The
4255 base of the line number information for the table is stored in
4256 the symbol associated with the function.
4257
00692651
ILT
4258 Note: The PE format uses line number 0 for a flag indicating a
4259 new source file.
4260
252b5132
RH
4261 The information is copied from the external to the internal
4262 table, and each symbol which marks a function is marked by
4263 pointing its...
4264
4265 How does this work ?
252b5132
RH
4266*/
4267
e708816d
NC
4268static int
4269coff_sort_func_alent (const void * arg1, const void * arg2)
4270{
4271 const alent *al1 = *(const alent **) arg1;
4272 const alent *al2 = *(const alent **) arg2;
4273 const coff_symbol_type *s1 = (const coff_symbol_type *) (al1->u.sym);
4274 const coff_symbol_type *s2 = (const coff_symbol_type *) (al2->u.sym);
4275
4276 if (s1->symbol.value < s2->symbol.value)
4277 return -1;
4278 else if (s1->symbol.value > s2->symbol.value)
4279 return 1;
4280
4281 return 0;
4282}
4283
b34976b6 4284static bfd_boolean
7920ce38 4285coff_slurp_line_table (bfd *abfd, asection *asect)
252b5132
RH
4286{
4287 LINENO *native_lineno;
4288 alent *lineno_cache;
dc810e39 4289 bfd_size_type amt;
e708816d
NC
4290 unsigned int counter;
4291 alent *cache_ptr;
4292 bfd_vma prev_offset = 0;
4293 int ordered = 1;
4294 unsigned int nbr_func;
4295 LINENO *src;
252b5132 4296
7920ce38 4297 BFD_ASSERT (asect->lineno == NULL);
252b5132 4298
dc810e39
AM
4299 amt = (bfd_size_type) bfd_coff_linesz (abfd) * asect->lineno_count;
4300 native_lineno = (LINENO *) buy_and_read (abfd, asect->line_filepos, amt);
14abcef9
NC
4301 if (native_lineno == NULL)
4302 {
4303 (*_bfd_error_handler)
d003868e 4304 (_("%B: warning: line number table read failed"), abfd);
14abcef9
NC
4305 return FALSE;
4306 }
e708816d 4307
dc810e39 4308 amt = ((bfd_size_type) asect->lineno_count + 1) * sizeof (alent);
7920ce38 4309 lineno_cache = bfd_alloc (abfd, amt);
252b5132 4310 if (lineno_cache == NULL)
b34976b6 4311 return FALSE;
e708816d
NC
4312
4313 cache_ptr = lineno_cache;
4314 src = native_lineno;
4315 nbr_func = 0;
4316
4317 for (counter = 0; counter < asect->lineno_count; counter++)
252b5132 4318 {
e708816d 4319 struct internal_lineno dst;
252b5132 4320
e708816d
NC
4321 bfd_coff_swap_lineno_in (abfd, src, &dst);
4322 cache_ptr->line_number = dst.l_lnno;
4323
4324 if (cache_ptr->line_number == 0)
252b5132 4325 {
e708816d
NC
4326 bfd_boolean warned;
4327 bfd_signed_vma symndx;
4328 coff_symbol_type *sym;
4329
4330 nbr_func++;
4331 warned = FALSE;
4332 symndx = dst.l_addr.l_symndx;
4333 if (symndx < 0
4334 || (bfd_vma) symndx >= obj_raw_syment_count (abfd))
4335 {
4336 (*_bfd_error_handler)
4337 (_("%B: warning: illegal symbol index %ld in line numbers"),
4338 abfd, dst.l_addr.l_symndx);
4339 symndx = 0;
4340 warned = TRUE;
4341 }
ed781d5d 4342
e708816d
NC
4343 /* FIXME: We should not be casting between ints and
4344 pointers like this. */
4345 sym = ((coff_symbol_type *)
4346 ((symndx + obj_raw_syments (abfd))
4347 ->u.syment._n._n_n._n_zeroes));
4348 cache_ptr->u.sym = (asymbol *) sym;
4349 if (sym->lineno != NULL && ! warned)
4350 (*_bfd_error_handler)
4351 (_("%B: warning: duplicate line number information for `%s'"),
4352 abfd, bfd_asymbol_name (&sym->symbol));
4353
4354 sym->lineno = cache_ptr;
4355 if (sym->symbol.value < prev_offset)
4356 ordered = 0;
4357 prev_offset = sym->symbol.value;
4358 }
4359 else
4360 cache_ptr->u.offset = dst.l_addr.l_paddr
4361 - bfd_section_vma (abfd, asect);
4362
4363 cache_ptr++;
4364 src++;
4365 }
4366 cache_ptr->line_number = 0;
4367
4368 /* On some systems (eg AIX5.3) the lineno table may not be sorted. */
4369 if (!ordered)
4370 {
4371 /* Sort the table. */
4372 alent **func_table;
4373 alent *n_lineno_cache;
4374
4375 /* Create a table of functions. */
4376 func_table = bfd_malloc (nbr_func * sizeof (alent *));
4377 if (func_table != NULL)
4378 {
4379 alent **p = func_table;
4380 unsigned int i;
4381
4382 for (i = 0; i < counter; i++)
4383 if (lineno_cache[i].line_number == 0)
4384 *p++ = &lineno_cache[i];
252b5132 4385
e708816d
NC
4386 /* Sort by functions. */
4387 qsort (func_table, nbr_func, sizeof (alent *), coff_sort_func_alent);
4388
4389 /* Create the new sorted table. */
4390 n_lineno_cache = bfd_alloc (abfd, amt);
4391 if (n_lineno_cache != NULL)
252b5132 4392 {
e708816d
NC
4393 alent *n_cache_ptr = n_lineno_cache;
4394
4395 for (i = 0; i < nbr_func; i++)
252b5132 4396 {
e708816d
NC
4397 coff_symbol_type *sym;
4398 alent *old_ptr = func_table[i];
4399
4400 /* Copy the function entry and update it. */
4401 *n_cache_ptr = *old_ptr;
4402 sym = (coff_symbol_type *)n_cache_ptr->u.sym;
4403 sym->lineno = n_cache_ptr;
4404 n_cache_ptr++;
4405 old_ptr++;
4406
4407 /* Copy the line number entries. */
4408 while (old_ptr->line_number != 0)
4409 *n_cache_ptr++ = *old_ptr++;
252b5132 4410 }
e708816d
NC
4411 n_cache_ptr->line_number = 0;
4412 bfd_release (abfd, lineno_cache);
4413 lineno_cache = n_lineno_cache;
252b5132 4414 }
e708816d 4415 free (func_table);
252b5132 4416 }
252b5132 4417 }
e708816d 4418
252b5132 4419 asect->lineno = lineno_cache;
e708816d 4420 bfd_release (abfd, native_lineno);
b34976b6 4421 return TRUE;
252b5132
RH
4422}
4423
00692651
ILT
4424/* Slurp in the symbol table, converting it to generic form. Note
4425 that if coff_relocate_section is defined, the linker will read
4426 symbols via coff_link_add_symbols, rather than via this routine. */
4427
b34976b6 4428static bfd_boolean
7920ce38 4429coff_slurp_symbol_table (bfd * abfd)
252b5132
RH
4430{
4431 combined_entry_type *native_symbols;
4432 coff_symbol_type *cached_area;
4433 unsigned int *table_ptr;
dc810e39 4434 bfd_size_type amt;
252b5132
RH
4435 unsigned int number_of_symbols = 0;
4436
4437 if (obj_symbols (abfd))
b34976b6 4438 return TRUE;
252b5132 4439
ed781d5d 4440 /* Read in the symbol table. */
252b5132 4441 if ((native_symbols = coff_get_normalized_symtab (abfd)) == NULL)
ed781d5d 4442 return FALSE;
252b5132 4443
ed781d5d 4444 /* Allocate enough room for all the symbols in cached form. */
dc810e39
AM
4445 amt = obj_raw_syment_count (abfd);
4446 amt *= sizeof (coff_symbol_type);
7920ce38 4447 cached_area = bfd_alloc (abfd, amt);
252b5132 4448 if (cached_area == NULL)
b34976b6 4449 return FALSE;
dc810e39
AM
4450
4451 amt = obj_raw_syment_count (abfd);
4452 amt *= sizeof (unsigned int);
7920ce38 4453 table_ptr = bfd_alloc (abfd, amt);
252b5132
RH
4454
4455 if (table_ptr == NULL)
b34976b6 4456 return FALSE;
252b5132
RH
4457 else
4458 {
4459 coff_symbol_type *dst = cached_area;
4460 unsigned int last_native_index = obj_raw_syment_count (abfd);
4461 unsigned int this_index = 0;
ed781d5d 4462
252b5132
RH
4463 while (this_index < last_native_index)
4464 {
4465 combined_entry_type *src = native_symbols + this_index;
4466 table_ptr[this_index] = number_of_symbols;
4467 dst->symbol.the_bfd = abfd;
4468
4469 dst->symbol.name = (char *) (src->u.syment._n._n_n._n_offset);
4470 /* We use the native name field to point to the cached field. */
d2df793a 4471 src->u.syment._n._n_n._n_zeroes = (bfd_hostptr_t) dst;
252b5132
RH
4472 dst->symbol.section = coff_section_from_bfd_index (abfd,
4473 src->u.syment.n_scnum);
4474 dst->symbol.flags = 0;
b34976b6 4475 dst->done_lineno = FALSE;
252b5132
RH
4476
4477 switch (src->u.syment.n_sclass)
4478 {
4479#ifdef I960
4480 case C_LEAFEXT:
ed781d5d 4481 /* Fall through to next case. */
252b5132
RH
4482#endif
4483
4484 case C_EXT:
4485 case C_WEAKEXT:
4486#if defined ARM
4487 case C_THUMBEXT:
4488 case C_THUMBEXTFUNC:
4489#endif
4490#ifdef RS6000COFF_C
4491 case C_HIDEXT:
4492#endif
4493#ifdef C_SYSTEM
ed781d5d 4494 case C_SYSTEM: /* System Wide variable. */
252b5132
RH
4495#endif
4496#ifdef COFF_WITH_PE
ed781d5d 4497 /* In PE, 0x68 (104) denotes a section symbol. */
252b5132 4498 case C_SECTION:
5d54c628 4499 /* In PE, 0x69 (105) denotes a weak external symbol. */
252b5132
RH
4500 case C_NT_WEAK:
4501#endif
5d54c628 4502 switch (coff_classify_symbol (abfd, &src->u.syment))
252b5132 4503 {
5d54c628 4504 case COFF_SYMBOL_GLOBAL:
252b5132 4505 dst->symbol.flags = BSF_EXPORT | BSF_GLOBAL;
252b5132
RH
4506#if defined COFF_WITH_PE
4507 /* PE sets the symbol to a value relative to the
4508 start of the section. */
4509 dst->symbol.value = src->u.syment.n_value;
4510#else
4511 dst->symbol.value = (src->u.syment.n_value
4512 - dst->symbol.section->vma);
4513#endif
252b5132 4514 if (ISFCN ((src->u.syment.n_type)))
7920ce38
NC
4515 /* A function ext does not go at the end of a
4516 file. */
4517 dst->symbol.flags |= BSF_NOT_AT_END | BSF_FUNCTION;
5d54c628
ILT
4518 break;
4519
4520 case COFF_SYMBOL_COMMON:
4521 dst->symbol.section = bfd_com_section_ptr;
4522 dst->symbol.value = src->u.syment.n_value;
4523 break;
4524
4525 case COFF_SYMBOL_UNDEFINED:
4526 dst->symbol.section = bfd_und_section_ptr;
4527 dst->symbol.value = 0;
e60b52c6 4528 break;
5d54c628
ILT
4529
4530 case COFF_SYMBOL_PE_SECTION:
4531 dst->symbol.flags |= BSF_EXPORT | BSF_SECTION_SYM;
4532 dst->symbol.value = 0;
4533 break;
4534
4535 case COFF_SYMBOL_LOCAL:
4536 dst->symbol.flags = BSF_LOCAL;
4537#if defined COFF_WITH_PE
4538 /* PE sets the symbol to a value relative to the
4539 start of the section. */
4540 dst->symbol.value = src->u.syment.n_value;
4541#else
4542 dst->symbol.value = (src->u.syment.n_value
4543 - dst->symbol.section->vma);
4544#endif
4545 if (ISFCN ((src->u.syment.n_type)))
4546 dst->symbol.flags |= BSF_NOT_AT_END | BSF_FUNCTION;
4547 break;
252b5132
RH
4548 }
4549
4550#ifdef RS6000COFF_C
252b5132
RH
4551 /* A symbol with a csect entry should not go at the end. */
4552 if (src->u.syment.n_numaux > 0)
4553 dst->symbol.flags |= BSF_NOT_AT_END;
4554#endif
4555
4556#ifdef COFF_WITH_PE
4557 if (src->u.syment.n_sclass == C_NT_WEAK)
a181be0a
NC
4558 dst->symbol.flags |= BSF_WEAK;
4559
ec0ef80e
DD
4560 if (src->u.syment.n_sclass == C_SECTION
4561 && src->u.syment.n_scnum > 0)
eb1e0e80 4562 dst->symbol.flags = BSF_LOCAL;
252b5132 4563#endif
252b5132 4564 if (src->u.syment.n_sclass == C_WEAKEXT)
a181be0a 4565 dst->symbol.flags |= BSF_WEAK;
252b5132
RH
4566
4567 break;
4568
ed781d5d 4569 case C_STAT: /* Static. */
252b5132 4570#ifdef I960
ed781d5d 4571 case C_LEAFSTAT: /* Static leaf procedure. */
252b5132 4572#endif
e60b52c6 4573#if defined ARM
ed781d5d
NC
4574 case C_THUMBSTAT: /* Thumb static. */
4575 case C_THUMBLABEL: /* Thumb label. */
4576 case C_THUMBSTATFUNC:/* Thumb static function. */
252b5132 4577#endif
ed781d5d 4578 case C_LABEL: /* Label. */
00692651 4579 if (src->u.syment.n_scnum == N_DEBUG)
252b5132
RH
4580 dst->symbol.flags = BSF_DEBUGGING;
4581 else
4582 dst->symbol.flags = BSF_LOCAL;
4583
4584 /* Base the value as an index from the base of the
4585 section, if there is one. */
4586 if (dst->symbol.section)
4587 {
4588#if defined COFF_WITH_PE
4589 /* PE sets the symbol to a value relative to the
4590 start of the section. */
4591 dst->symbol.value = src->u.syment.n_value;
4592#else
4593 dst->symbol.value = (src->u.syment.n_value
4594 - dst->symbol.section->vma);
4595#endif
4596 }
4597 else
4598 dst->symbol.value = src->u.syment.n_value;
4599 break;
4600
ed781d5d
NC
4601 case C_MOS: /* Member of structure. */
4602 case C_EOS: /* End of structure. */
ed781d5d
NC
4603 case C_REGPARM: /* Register parameter. */
4604 case C_REG: /* register variable. */
5c4491d3 4605 /* C_AUTOARG conflicts with TI COFF C_UEXT. */
81635ce4 4606#if !defined (TIC80COFF) && !defined (TICOFF)
252b5132 4607#ifdef C_AUTOARG
ed781d5d 4608 case C_AUTOARG: /* 960-specific storage class. */
252b5132
RH
4609#endif
4610#endif
ed781d5d 4611 case C_TPDEF: /* Type definition. */
252b5132 4612 case C_ARG:
ed781d5d
NC
4613 case C_AUTO: /* Automatic variable. */
4614 case C_FIELD: /* Bit field. */
4615 case C_ENTAG: /* Enumeration tag. */
4616 case C_MOE: /* Member of enumeration. */
4617 case C_MOU: /* Member of union. */
4618 case C_UNTAG: /* Union tag. */
252b5132
RH
4619 dst->symbol.flags = BSF_DEBUGGING;
4620 dst->symbol.value = (src->u.syment.n_value);
4621 break;
4622
ed781d5d
NC
4623 case C_FILE: /* File name. */
4624 case C_STRTAG: /* Structure tag. */
252b5132
RH
4625#ifdef RS6000COFF_C
4626 case C_GSYM:
4627 case C_LSYM:
4628 case C_PSYM:
4629 case C_RSYM:
4630 case C_RPSYM:
4631 case C_STSYM:
f9f3cf65 4632 case C_TCSYM:
252b5132 4633 case C_BCOMM:
f9f3cf65 4634 case C_ECOML:
252b5132
RH
4635 case C_ECOMM:
4636 case C_DECL:
4637 case C_ENTRY:
4638 case C_FUN:
4639 case C_ESTAT:
4640#endif
4641 dst->symbol.flags = BSF_DEBUGGING;
4642 dst->symbol.value = (src->u.syment.n_value);
4643 break;
4644
4645#ifdef RS6000COFF_C
ed781d5d
NC
4646 case C_BINCL: /* Beginning of include file. */
4647 case C_EINCL: /* Ending of include file. */
252b5132
RH
4648 /* The value is actually a pointer into the line numbers
4649 of the file. We locate the line number entry, and
4650 set the section to the section which contains it, and
4651 the value to the index in that section. */
4652 {
4653 asection *sec;
4654
4655 dst->symbol.flags = BSF_DEBUGGING;
4656 for (sec = abfd->sections; sec != NULL; sec = sec->next)
4657 if (sec->line_filepos <= (file_ptr) src->u.syment.n_value
4658 && ((file_ptr) (sec->line_filepos
6b3b007b 4659 + sec->lineno_count * bfd_coff_linesz (abfd))
252b5132
RH
4660 > (file_ptr) src->u.syment.n_value))
4661 break;
4662 if (sec == NULL)
4663 dst->symbol.value = 0;
4664 else
4665 {
4666 dst->symbol.section = sec;
4667 dst->symbol.value = ((src->u.syment.n_value
4668 - sec->line_filepos)
6b3b007b 4669 / bfd_coff_linesz (abfd));
252b5132
RH
4670 src->fix_line = 1;
4671 }
4672 }
4673 break;
4674
4675 case C_BSTAT:
4676 dst->symbol.flags = BSF_DEBUGGING;
4677
4678 /* The value is actually a symbol index. Save a pointer
4679 to the symbol instead of the index. FIXME: This
4680 should use a union. */
4681 src->u.syment.n_value =
4682 (long) (native_symbols + src->u.syment.n_value);
4683 dst->symbol.value = src->u.syment.n_value;
4684 src->fix_value = 1;
4685 break;
4686#endif
4687
ed781d5d
NC
4688 case C_BLOCK: /* ".bb" or ".eb". */
4689 case C_FCN: /* ".bf" or ".ef" (or PE ".lf"). */
4690 case C_EFCN: /* Physical end of function. */
252b5132
RH
4691#if defined COFF_WITH_PE
4692 /* PE sets the symbol to a value relative to the start
4693 of the section. */
4694 dst->symbol.value = src->u.syment.n_value;
d510f9a6
ILT
4695 if (strcmp (dst->symbol.name, ".bf") != 0)
4696 {
4697 /* PE uses funny values for .ef and .lf; don't
4698 relocate them. */
4699 dst->symbol.flags = BSF_DEBUGGING;
4700 }
4701 else
4702 dst->symbol.flags = BSF_DEBUGGING | BSF_DEBUGGING_RELOC;
252b5132
RH
4703#else
4704 /* Base the value as an index from the base of the
4705 section. */
d510f9a6 4706 dst->symbol.flags = BSF_LOCAL;
252b5132
RH
4707 dst->symbol.value = (src->u.syment.n_value
4708 - dst->symbol.section->vma);
4709#endif
4710 break;
4711
ed781d5d 4712 case C_STATLAB: /* Static load time label. */
34cbe64e
TW
4713 dst->symbol.value = src->u.syment.n_value;
4714 dst->symbol.flags = BSF_GLOBAL;
4715 break;
4716
252b5132 4717 case C_NULL:
00692651
ILT
4718 /* PE DLLs sometimes have zeroed out symbols for some
4719 reason. Just ignore them without a warning. */
4720 if (src->u.syment.n_type == 0
4721 && src->u.syment.n_value == 0
4722 && src->u.syment.n_scnum == 0)
4723 break;
4724 /* Fall through. */
ed781d5d
NC
4725 case C_EXTDEF: /* External definition. */
4726 case C_ULABEL: /* Undefined label. */
4727 case C_USTATIC: /* Undefined static. */
252b5132
RH
4728#ifndef COFF_WITH_PE
4729 /* C_LINE in regular coff is 0x68. NT has taken over this storage
ed781d5d
NC
4730 class to represent a section symbol. */
4731 case C_LINE: /* line # reformatted as symbol table entry. */
252b5132 4732 /* NT uses 0x67 for a weak symbol, not C_ALIAS. */
ed781d5d 4733 case C_ALIAS: /* Duplicate tag. */
252b5132 4734#endif
ed781d5d 4735 /* New storage classes for TI COFF. */
81635ce4 4736#if defined(TIC80COFF) || defined(TICOFF)
ed781d5d 4737 case C_UEXT: /* Tentative external definition. */
252b5132 4738#endif
ed781d5d
NC
4739 case C_EXTLAB: /* External load time label. */
4740 case C_HIDDEN: /* Ext symbol in dmert public lib. */
252b5132
RH
4741 default:
4742 (*_bfd_error_handler)
d003868e
AM
4743 (_("%B: Unrecognized storage class %d for %s symbol `%s'"),
4744 abfd, src->u.syment.n_sclass,
252b5132
RH
4745 dst->symbol.section->name, dst->symbol.name);
4746 dst->symbol.flags = BSF_DEBUGGING;
4747 dst->symbol.value = (src->u.syment.n_value);
4748 break;
4749 }
4750
252b5132
RH
4751 dst->native = src;
4752
4753 dst->symbol.udata.i = 0;
7920ce38 4754 dst->lineno = NULL;
252b5132
RH
4755 this_index += (src->u.syment.n_numaux) + 1;
4756 dst++;
4757 number_of_symbols++;
ed781d5d
NC
4758 }
4759 }
252b5132
RH
4760
4761 obj_symbols (abfd) = cached_area;
4762 obj_raw_syments (abfd) = native_symbols;
4763
4764 bfd_get_symcount (abfd) = number_of_symbols;
4765 obj_convert (abfd) = table_ptr;
ed781d5d 4766 /* Slurp the line tables for each section too. */
252b5132
RH
4767 {
4768 asection *p;
ed781d5d 4769
252b5132
RH
4770 p = abfd->sections;
4771 while (p)
4772 {
4773 coff_slurp_line_table (abfd, p);
4774 p = p->next;
4775 }
4776 }
ed781d5d 4777
b34976b6 4778 return TRUE;
7920ce38 4779}
252b5132 4780
5d54c628
ILT
4781/* Classify a COFF symbol. A couple of targets have globally visible
4782 symbols which are not class C_EXT, and this handles those. It also
4783 recognizes some special PE cases. */
252b5132 4784
5d54c628 4785static enum coff_symbol_classification
7920ce38
NC
4786coff_classify_symbol (bfd *abfd,
4787 struct internal_syment *syment)
5d54c628
ILT
4788{
4789 /* FIXME: This partially duplicates the switch in
4790 coff_slurp_symbol_table. */
4791 switch (syment->n_sclass)
4792 {
4793 case C_EXT:
4794 case C_WEAKEXT:
252b5132 4795#ifdef I960
5d54c628 4796 case C_LEAFEXT:
252b5132 4797#endif
5d54c628
ILT
4798#ifdef ARM
4799 case C_THUMBEXT:
4800 case C_THUMBEXTFUNC:
252b5132 4801#endif
5d54c628
ILT
4802#ifdef C_SYSTEM
4803 case C_SYSTEM:
252b5132 4804#endif
5d54c628
ILT
4805#ifdef COFF_WITH_PE
4806 case C_NT_WEAK:
4807#endif
4808 if (syment->n_scnum == 0)
4809 {
4810 if (syment->n_value == 0)
4811 return COFF_SYMBOL_UNDEFINED;
4812 else
4813 return COFF_SYMBOL_COMMON;
4814 }
4815 return COFF_SYMBOL_GLOBAL;
4816
4817 default:
4818 break;
4819 }
252b5132 4820
5d54c628
ILT
4821#ifdef COFF_WITH_PE
4822 if (syment->n_sclass == C_STAT)
4823 {
4824 if (syment->n_scnum == 0)
7920ce38
NC
4825 /* The Microsoft compiler sometimes generates these if a
4826 small static function is inlined every time it is used.
4827 The function is discarded, but the symbol table entry
4828 remains. */
4829 return COFF_SYMBOL_LOCAL;
252b5132 4830
0717ebb7 4831#ifdef STRICT_PE_FORMAT
bd826630
ILT
4832 /* This is correct for Microsoft generated objects, but it
4833 breaks gas generated objects. */
5d54c628
ILT
4834 if (syment->n_value == 0)
4835 {
4836 asection *sec;
4837 char buf[SYMNMLEN + 1];
4838
4839 sec = coff_section_from_bfd_index (abfd, syment->n_scnum);
4840 if (sec != NULL
4841 && (strcmp (bfd_get_section_name (abfd, sec),
4842 _bfd_coff_internal_syment_name (abfd, syment, buf))
4843 == 0))
4844 return COFF_SYMBOL_PE_SECTION;
4845 }
bd826630 4846#endif
252b5132 4847
5d54c628
ILT
4848 return COFF_SYMBOL_LOCAL;
4849 }
252b5132 4850
5d54c628
ILT
4851 if (syment->n_sclass == C_SECTION)
4852 {
4853 /* In some cases in a DLL generated by the Microsoft linker, the
4854 n_value field will contain garbage. FIXME: This should
4855 probably be handled by the swapping function instead. */
4856 syment->n_value = 0;
4857 if (syment->n_scnum == 0)
4858 return COFF_SYMBOL_UNDEFINED;
4859 return COFF_SYMBOL_PE_SECTION;
4860 }
4861#endif /* COFF_WITH_PE */
252b5132 4862
5d54c628 4863 /* If it is not a global symbol, we presume it is a local symbol. */
5d54c628
ILT
4864 if (syment->n_scnum == 0)
4865 {
4866 char buf[SYMNMLEN + 1];
252b5132 4867
5d54c628 4868 (*_bfd_error_handler)
d003868e
AM
4869 (_("warning: %B: local symbol `%s' has no section"),
4870 abfd, _bfd_coff_internal_syment_name (abfd, syment, buf));
5d54c628 4871 }
252b5132 4872
5d54c628
ILT
4873 return COFF_SYMBOL_LOCAL;
4874}
252b5132
RH
4875
4876/*
4877SUBSUBSECTION
4878 Reading relocations
4879
4880 Coff relocations are easily transformed into the internal BFD form
4881 (@code{arelent}).
4882
4883 Reading a coff relocation table is done in the following stages:
4884
4885 o Read the entire coff relocation table into memory.
4886
4887 o Process each relocation in turn; first swap it from the
4888 external to the internal form.
4889
4890 o Turn the symbol referenced in the relocation's symbol index
4891 into a pointer into the canonical symbol table.
4892 This table is the same as the one returned by a call to
4893 @code{bfd_canonicalize_symtab}. The back end will call that
4894 routine and save the result if a canonicalization hasn't been done.
4895
4896 o The reloc index is turned into a pointer to a howto
4897 structure, in a back end specific way. For instance, the 386
4898 and 960 use the @code{r_type} to directly produce an index
4899 into a howto table vector; the 88k subtracts a number from the
4900 @code{r_type} field and creates an addend field.
252b5132
RH
4901*/
4902
4903#ifndef CALC_ADDEND
4904#define CALC_ADDEND(abfd, ptr, reloc, cache_ptr) \
4905 { \
7920ce38
NC
4906 coff_symbol_type *coffsym = NULL; \
4907 \
252b5132
RH
4908 if (ptr && bfd_asymbol_bfd (ptr) != abfd) \
4909 coffsym = (obj_symbols (abfd) \
4910 + (cache_ptr->sym_ptr_ptr - symbols)); \
4911 else if (ptr) \
4912 coffsym = coff_symbol_from (abfd, ptr); \
7920ce38 4913 if (coffsym != NULL \
252b5132
RH
4914 && coffsym->native->u.syment.n_scnum == 0) \
4915 cache_ptr->addend = 0; \
4916 else if (ptr && bfd_asymbol_bfd (ptr) == abfd \
7920ce38 4917 && ptr->section != NULL) \
252b5132
RH
4918 cache_ptr->addend = - (ptr->section->vma + ptr->value); \
4919 else \
4920 cache_ptr->addend = 0; \
4921 }
4922#endif
4923
b34976b6 4924static bfd_boolean
7920ce38 4925coff_slurp_reloc_table (bfd * abfd, sec_ptr asect, asymbol ** symbols)
252b5132
RH
4926{
4927 RELOC *native_relocs;
4928 arelent *reloc_cache;
4929 arelent *cache_ptr;
252b5132 4930 unsigned int idx;
dc810e39 4931 bfd_size_type amt;
252b5132
RH
4932
4933 if (asect->relocation)
b34976b6 4934 return TRUE;
252b5132 4935 if (asect->reloc_count == 0)
b34976b6 4936 return TRUE;
252b5132 4937 if (asect->flags & SEC_CONSTRUCTOR)
b34976b6 4938 return TRUE;
252b5132 4939 if (!coff_slurp_symbol_table (abfd))
b34976b6 4940 return FALSE;
7920ce38 4941
dc810e39
AM
4942 amt = (bfd_size_type) bfd_coff_relsz (abfd) * asect->reloc_count;
4943 native_relocs = (RELOC *) buy_and_read (abfd, asect->rel_filepos, amt);
4944 amt = (bfd_size_type) asect->reloc_count * sizeof (arelent);
7920ce38 4945 reloc_cache = bfd_alloc (abfd, amt);
252b5132 4946
a50b2160 4947 if (reloc_cache == NULL || native_relocs == NULL)
b34976b6 4948 return FALSE;
252b5132 4949
252b5132
RH
4950 for (idx = 0; idx < asect->reloc_count; idx++)
4951 {
4952 struct internal_reloc dst;
4953 struct external_reloc *src;
4954#ifndef RELOC_PROCESSING
4955 asymbol *ptr;
4956#endif
4957
4958 cache_ptr = reloc_cache + idx;
4959 src = native_relocs + idx;
4960
40b1c6c5 4961 dst.r_offset = 0;
252b5132
RH
4962 coff_swap_reloc_in (abfd, src, &dst);
4963
4964#ifdef RELOC_PROCESSING
4965 RELOC_PROCESSING (cache_ptr, &dst, symbols, abfd, asect);
4966#else
4967 cache_ptr->address = dst.r_vaddr;
4968
4969 if (dst.r_symndx != -1)
4970 {
4971 if (dst.r_symndx < 0 || dst.r_symndx >= obj_conv_table_size (abfd))
4972 {
4973 (*_bfd_error_handler)
d003868e
AM
4974 (_("%B: warning: illegal symbol index %ld in relocs"),
4975 abfd, dst.r_symndx);
252b5132
RH
4976 cache_ptr->sym_ptr_ptr = bfd_abs_section_ptr->symbol_ptr_ptr;
4977 ptr = NULL;
4978 }
4979 else
4980 {
4981 cache_ptr->sym_ptr_ptr = (symbols
4982 + obj_convert (abfd)[dst.r_symndx]);
4983 ptr = *(cache_ptr->sym_ptr_ptr);
4984 }
4985 }
4986 else
4987 {
4988 cache_ptr->sym_ptr_ptr = bfd_abs_section_ptr->symbol_ptr_ptr;
4989 ptr = NULL;
4990 }
4991
4992 /* The symbols definitions that we have read in have been
4993 relocated as if their sections started at 0. But the offsets
4994 refering to the symbols in the raw data have not been
4995 modified, so we have to have a negative addend to compensate.
4996
ed781d5d 4997 Note that symbols which used to be common must be left alone. */
252b5132 4998
ed781d5d 4999 /* Calculate any reloc addend by looking at the symbol. */
252b5132
RH
5000 CALC_ADDEND (abfd, ptr, dst, cache_ptr);
5001
5002 cache_ptr->address -= asect->vma;
7920ce38 5003 /* !! cache_ptr->section = NULL;*/
252b5132 5004
ed781d5d 5005 /* Fill in the cache_ptr->howto field from dst.r_type. */
252b5132
RH
5006 RTYPE2HOWTO (cache_ptr, &dst);
5007#endif /* RELOC_PROCESSING */
5008
5009 if (cache_ptr->howto == NULL)
5010 {
5011 (*_bfd_error_handler)
d003868e
AM
5012 (_("%B: illegal relocation type %d at address 0x%lx"),
5013 abfd, dst.r_type, (long) dst.r_vaddr);
252b5132 5014 bfd_set_error (bfd_error_bad_value);
b34976b6 5015 return FALSE;
252b5132
RH
5016 }
5017 }
5018
5019 asect->relocation = reloc_cache;
b34976b6 5020 return TRUE;
252b5132
RH
5021}
5022
5023#ifndef coff_rtype_to_howto
5024#ifdef RTYPE2HOWTO
5025
5026/* Get the howto structure for a reloc. This is only used if the file
5027 including this one defines coff_relocate_section to be
5028 _bfd_coff_generic_relocate_section, so it is OK if it does not
5029 always work. It is the responsibility of the including file to
5030 make sure it is reasonable if it is needed. */
5031
252b5132 5032static reloc_howto_type *
7920ce38
NC
5033coff_rtype_to_howto (bfd *abfd ATTRIBUTE_UNUSED,
5034 asection *sec ATTRIBUTE_UNUSED,
5035 struct internal_reloc *rel,
5036 struct coff_link_hash_entry *h ATTRIBUTE_UNUSED,
5037 struct internal_syment *sym ATTRIBUTE_UNUSED,
5038 bfd_vma *addendp ATTRIBUTE_UNUSED)
252b5132
RH
5039{
5040 arelent genrel;
5041
964597d0 5042 genrel.howto = NULL;
252b5132
RH
5043 RTYPE2HOWTO (&genrel, rel);
5044 return genrel.howto;
5045}
5046
5047#else /* ! defined (RTYPE2HOWTO) */
5048
5049#define coff_rtype_to_howto NULL
5050
5051#endif /* ! defined (RTYPE2HOWTO) */
5052#endif /* ! defined (coff_rtype_to_howto) */
5053
5054/* This is stupid. This function should be a boolean predicate. */
7920ce38 5055
252b5132 5056static long
7920ce38
NC
5057coff_canonicalize_reloc (bfd * abfd,
5058 sec_ptr section,
5059 arelent ** relptr,
5060 asymbol ** symbols)
252b5132
RH
5061{
5062 arelent *tblptr = section->relocation;
5063 unsigned int count = 0;
5064
252b5132
RH
5065 if (section->flags & SEC_CONSTRUCTOR)
5066 {
ed781d5d
NC
5067 /* This section has relocs made up by us, they are not in the
5068 file, so take them out of their chain and place them into
5069 the data area provided. */
252b5132 5070 arelent_chain *chain = section->constructor_chain;
ed781d5d 5071
252b5132
RH
5072 for (count = 0; count < section->reloc_count; count++)
5073 {
5074 *relptr++ = &chain->relent;
5075 chain = chain->next;
5076 }
252b5132
RH
5077 }
5078 else
5079 {
5080 if (! coff_slurp_reloc_table (abfd, section, symbols))
5081 return -1;
5082
5083 tblptr = section->relocation;
5084
5085 for (; count++ < section->reloc_count;)
5086 *relptr++ = tblptr++;
252b5132
RH
5087 }
5088 *relptr = 0;
5089 return section->reloc_count;
5090}
5091
252b5132
RH
5092#ifndef coff_reloc16_estimate
5093#define coff_reloc16_estimate dummy_reloc16_estimate
5094
252b5132 5095static int
7920ce38
NC
5096dummy_reloc16_estimate (bfd *abfd ATTRIBUTE_UNUSED,
5097 asection *input_section ATTRIBUTE_UNUSED,
5098 arelent *reloc ATTRIBUTE_UNUSED,
5099 unsigned int shrink ATTRIBUTE_UNUSED,
5100 struct bfd_link_info *link_info ATTRIBUTE_UNUSED)
252b5132
RH
5101{
5102 abort ();
00692651 5103 return 0;
252b5132
RH
5104}
5105
5106#endif
5107
5108#ifndef coff_reloc16_extra_cases
5109
5110#define coff_reloc16_extra_cases dummy_reloc16_extra_cases
5111
5112/* This works even if abort is not declared in any header file. */
5113
252b5132 5114static void
7920ce38
NC
5115dummy_reloc16_extra_cases (bfd *abfd ATTRIBUTE_UNUSED,
5116 struct bfd_link_info *link_info ATTRIBUTE_UNUSED,
5117 struct bfd_link_order *link_order ATTRIBUTE_UNUSED,
5118 arelent *reloc ATTRIBUTE_UNUSED,
5119 bfd_byte *data ATTRIBUTE_UNUSED,
5120 unsigned int *src_ptr ATTRIBUTE_UNUSED,
5121 unsigned int *dst_ptr ATTRIBUTE_UNUSED)
252b5132
RH
5122{
5123 abort ();
5124}
5125#endif
5126
e2d34d7d
DJ
5127#ifndef coff_bfd_link_hash_table_free
5128#define coff_bfd_link_hash_table_free _bfd_generic_link_hash_table_free
5129#endif
5130
252b5132
RH
5131/* If coff_relocate_section is defined, we can use the optimized COFF
5132 backend linker. Otherwise we must continue to use the old linker. */
7920ce38 5133
252b5132 5134#ifdef coff_relocate_section
7920ce38 5135
252b5132
RH
5136#ifndef coff_bfd_link_hash_table_create
5137#define coff_bfd_link_hash_table_create _bfd_coff_link_hash_table_create
5138#endif
5139#ifndef coff_bfd_link_add_symbols
5140#define coff_bfd_link_add_symbols _bfd_coff_link_add_symbols
5141#endif
5142#ifndef coff_bfd_final_link
5143#define coff_bfd_final_link _bfd_coff_final_link
5144#endif
7920ce38 5145
252b5132 5146#else /* ! defined (coff_relocate_section) */
7920ce38 5147
252b5132
RH
5148#define coff_relocate_section NULL
5149#ifndef coff_bfd_link_hash_table_create
5150#define coff_bfd_link_hash_table_create _bfd_generic_link_hash_table_create
5151#endif
5152#ifndef coff_bfd_link_add_symbols
5153#define coff_bfd_link_add_symbols _bfd_generic_link_add_symbols
5154#endif
5155#define coff_bfd_final_link _bfd_generic_final_link
7920ce38 5156
252b5132
RH
5157#endif /* ! defined (coff_relocate_section) */
5158
7920ce38 5159#define coff_bfd_link_just_syms _bfd_generic_link_just_syms
252b5132
RH
5160#define coff_bfd_link_split_section _bfd_generic_link_split_section
5161
5162#ifndef coff_start_final_link
5163#define coff_start_final_link NULL
5164#endif
5165
5166#ifndef coff_adjust_symndx
5167#define coff_adjust_symndx NULL
5168#endif
5169
5170#ifndef coff_link_add_one_symbol
5171#define coff_link_add_one_symbol _bfd_generic_link_add_one_symbol
5172#endif
5173
5174#ifndef coff_link_output_has_begun
5175
b34976b6 5176static bfd_boolean
7920ce38
NC
5177coff_link_output_has_begun (bfd * abfd,
5178 struct coff_final_link_info * info ATTRIBUTE_UNUSED)
252b5132
RH
5179{
5180 return abfd->output_has_begun;
5181}
5182#endif
5183
5184#ifndef coff_final_link_postscript
5185
b34976b6 5186static bfd_boolean
7920ce38
NC
5187coff_final_link_postscript (bfd * abfd ATTRIBUTE_UNUSED,
5188 struct coff_final_link_info * pfinfo ATTRIBUTE_UNUSED)
252b5132 5189{
b34976b6 5190 return TRUE;
252b5132
RH
5191}
5192#endif
5193
5194#ifndef coff_SWAP_aux_in
5195#define coff_SWAP_aux_in coff_swap_aux_in
5196#endif
5197#ifndef coff_SWAP_sym_in
5198#define coff_SWAP_sym_in coff_swap_sym_in
5199#endif
5200#ifndef coff_SWAP_lineno_in
5201#define coff_SWAP_lineno_in coff_swap_lineno_in
5202#endif
5203#ifndef coff_SWAP_aux_out
5204#define coff_SWAP_aux_out coff_swap_aux_out
5205#endif
5206#ifndef coff_SWAP_sym_out
5207#define coff_SWAP_sym_out coff_swap_sym_out
5208#endif
5209#ifndef coff_SWAP_lineno_out
5210#define coff_SWAP_lineno_out coff_swap_lineno_out
5211#endif
5212#ifndef coff_SWAP_reloc_out
5213#define coff_SWAP_reloc_out coff_swap_reloc_out
5214#endif
5215#ifndef coff_SWAP_filehdr_out
5216#define coff_SWAP_filehdr_out coff_swap_filehdr_out
5217#endif
5218#ifndef coff_SWAP_aouthdr_out
5219#define coff_SWAP_aouthdr_out coff_swap_aouthdr_out
5220#endif
5221#ifndef coff_SWAP_scnhdr_out
5222#define coff_SWAP_scnhdr_out coff_swap_scnhdr_out
5223#endif
5224#ifndef coff_SWAP_reloc_in
5225#define coff_SWAP_reloc_in coff_swap_reloc_in
5226#endif
5227#ifndef coff_SWAP_filehdr_in
5228#define coff_SWAP_filehdr_in coff_swap_filehdr_in
5229#endif
5230#ifndef coff_SWAP_aouthdr_in
5231#define coff_SWAP_aouthdr_in coff_swap_aouthdr_in
5232#endif
5233#ifndef coff_SWAP_scnhdr_in
5234#define coff_SWAP_scnhdr_in coff_swap_scnhdr_in
5235#endif
5236
cb7a88a4 5237static const bfd_coff_backend_data bfd_coff_std_swap_table ATTRIBUTE_UNUSED =
252b5132
RH
5238{
5239 coff_SWAP_aux_in, coff_SWAP_sym_in, coff_SWAP_lineno_in,
5240 coff_SWAP_aux_out, coff_SWAP_sym_out,
5241 coff_SWAP_lineno_out, coff_SWAP_reloc_out,
5242 coff_SWAP_filehdr_out, coff_SWAP_aouthdr_out,
5243 coff_SWAP_scnhdr_out,
692b7d62 5244 FILHSZ, AOUTSZ, SCNHSZ, SYMESZ, AUXESZ, RELSZ, LINESZ, FILNMLEN,
252b5132 5245#ifdef COFF_LONG_FILENAMES
b34976b6 5246 TRUE,
252b5132 5247#else
b34976b6 5248 FALSE,
252b5132
RH
5249#endif
5250#ifdef COFF_LONG_SECTION_NAMES
b34976b6 5251 TRUE,
252b5132 5252#else
b34976b6 5253 FALSE,
252b5132 5254#endif
a022216b 5255 COFF_DEFAULT_SECTION_ALIGNMENT_POWER,
7f6d05e8 5256#ifdef COFF_FORCE_SYMBOLS_IN_STRINGS
b34976b6 5257 TRUE,
7f6d05e8 5258#else
b34976b6 5259 FALSE,
7f6d05e8
CP
5260#endif
5261#ifdef COFF_DEBUG_STRING_WIDE_PREFIX
5262 4,
5263#else
5264 2,
5265#endif
252b5132
RH
5266 coff_SWAP_filehdr_in, coff_SWAP_aouthdr_in, coff_SWAP_scnhdr_in,
5267 coff_SWAP_reloc_in, coff_bad_format_hook, coff_set_arch_mach_hook,
5268 coff_mkobject_hook, styp_to_sec_flags, coff_set_alignment_hook,
5269 coff_slurp_symbol_table, symname_in_debug_hook, coff_pointerize_aux_hook,
5270 coff_print_aux, coff_reloc16_extra_cases, coff_reloc16_estimate,
5d54c628 5271 coff_classify_symbol, coff_compute_section_file_positions,
252b5132
RH
5272 coff_start_final_link, coff_relocate_section, coff_rtype_to_howto,
5273 coff_adjust_symndx, coff_link_add_one_symbol,
2b5c217d
NC
5274 coff_link_output_has_begun, coff_final_link_postscript,
5275 bfd_pe_print_pdata
252b5132
RH
5276};
5277
5a5b9651
SS
5278#ifdef TICOFF
5279/* COFF0 differs in file/section header size and relocation entry size. */
7920ce38 5280
5a5b9651
SS
5281static const bfd_coff_backend_data ticoff0_swap_table =
5282{
5283 coff_SWAP_aux_in, coff_SWAP_sym_in, coff_SWAP_lineno_in,
5284 coff_SWAP_aux_out, coff_SWAP_sym_out,
5285 coff_SWAP_lineno_out, coff_SWAP_reloc_out,
5286 coff_SWAP_filehdr_out, coff_SWAP_aouthdr_out,
5287 coff_SWAP_scnhdr_out,
5288 FILHSZ_V0, AOUTSZ, SCNHSZ_V01, SYMESZ, AUXESZ, RELSZ_V0, LINESZ, FILNMLEN,
5289#ifdef COFF_LONG_FILENAMES
5290 TRUE,
5291#else
5292 FALSE,
5293#endif
5294#ifdef COFF_LONG_SECTION_NAMES
5295 TRUE,
5296#else
5297 FALSE,
5298#endif
5299 COFF_DEFAULT_SECTION_ALIGNMENT_POWER,
5300#ifdef COFF_FORCE_SYMBOLS_IN_STRINGS
5301 TRUE,
5302#else
5303 FALSE,
5304#endif
5305#ifdef COFF_DEBUG_STRING_WIDE_PREFIX
5306 4,
5307#else
5308 2,
5309#endif
5310 coff_SWAP_filehdr_in, coff_SWAP_aouthdr_in, coff_SWAP_scnhdr_in,
5311 coff_SWAP_reloc_in, ticoff0_bad_format_hook, coff_set_arch_mach_hook,
5312 coff_mkobject_hook, styp_to_sec_flags, coff_set_alignment_hook,
5313 coff_slurp_symbol_table, symname_in_debug_hook, coff_pointerize_aux_hook,
5314 coff_print_aux, coff_reloc16_extra_cases, coff_reloc16_estimate,
5315 coff_classify_symbol, coff_compute_section_file_positions,
5316 coff_start_final_link, coff_relocate_section, coff_rtype_to_howto,
5317 coff_adjust_symndx, coff_link_add_one_symbol,
2b5c217d
NC
5318 coff_link_output_has_begun, coff_final_link_postscript,
5319 bfd_pe_print_pdata
5a5b9651
SS
5320};
5321#endif
5322
5323#ifdef TICOFF
5324/* COFF1 differs in section header size. */
7920ce38 5325
5a5b9651
SS
5326static const bfd_coff_backend_data ticoff1_swap_table =
5327{
5328 coff_SWAP_aux_in, coff_SWAP_sym_in, coff_SWAP_lineno_in,
5329 coff_SWAP_aux_out, coff_SWAP_sym_out,
5330 coff_SWAP_lineno_out, coff_SWAP_reloc_out,
5331 coff_SWAP_filehdr_out, coff_SWAP_aouthdr_out,
5332 coff_SWAP_scnhdr_out,
5333 FILHSZ, AOUTSZ, SCNHSZ_V01, SYMESZ, AUXESZ, RELSZ, LINESZ, FILNMLEN,
5334#ifdef COFF_LONG_FILENAMES
5335 TRUE,
5336#else
5337 FALSE,
5338#endif
5339#ifdef COFF_LONG_SECTION_NAMES
5340 TRUE,
5341#else
5342 FALSE,
5343#endif
5344 COFF_DEFAULT_SECTION_ALIGNMENT_POWER,
5345#ifdef COFF_FORCE_SYMBOLS_IN_STRINGS
5346 TRUE,
5347#else
5348 FALSE,
5349#endif
5350#ifdef COFF_DEBUG_STRING_WIDE_PREFIX
5351 4,
5352#else
5353 2,
5354#endif
5355 coff_SWAP_filehdr_in, coff_SWAP_aouthdr_in, coff_SWAP_scnhdr_in,
5356 coff_SWAP_reloc_in, ticoff1_bad_format_hook, coff_set_arch_mach_hook,
5357 coff_mkobject_hook, styp_to_sec_flags, coff_set_alignment_hook,
5358 coff_slurp_symbol_table, symname_in_debug_hook, coff_pointerize_aux_hook,
5359 coff_print_aux, coff_reloc16_extra_cases, coff_reloc16_estimate,
5360 coff_classify_symbol, coff_compute_section_file_positions,
5361 coff_start_final_link, coff_relocate_section, coff_rtype_to_howto,
5362 coff_adjust_symndx, coff_link_add_one_symbol,
2b5c217d
NC
5363 coff_link_output_has_begun, coff_final_link_postscript,
5364 bfd_pe_print_pdata /* huh */
5a5b9651
SS
5365};
5366#endif
5367
252b5132
RH
5368#ifndef coff_close_and_cleanup
5369#define coff_close_and_cleanup _bfd_generic_close_and_cleanup
5370#endif
5371
5372#ifndef coff_bfd_free_cached_info
5373#define coff_bfd_free_cached_info _bfd_generic_bfd_free_cached_info
5374#endif
5375
5376#ifndef coff_get_section_contents
5377#define coff_get_section_contents _bfd_generic_get_section_contents
5378#endif
5379
5380#ifndef coff_bfd_copy_private_symbol_data
5381#define coff_bfd_copy_private_symbol_data _bfd_generic_bfd_copy_private_symbol_data
5382#endif
5383
80fccad2
BW
5384#ifndef coff_bfd_copy_private_header_data
5385#define coff_bfd_copy_private_header_data _bfd_generic_bfd_copy_private_header_data
5386#endif
5387
252b5132
RH
5388#ifndef coff_bfd_copy_private_section_data
5389#define coff_bfd_copy_private_section_data _bfd_generic_bfd_copy_private_section_data
5390#endif
5391
e60b52c6 5392#ifndef coff_bfd_copy_private_bfd_data
252b5132
RH
5393#define coff_bfd_copy_private_bfd_data _bfd_generic_bfd_copy_private_bfd_data
5394#endif
5395
5396#ifndef coff_bfd_merge_private_bfd_data
5397#define coff_bfd_merge_private_bfd_data _bfd_generic_bfd_merge_private_bfd_data
5398#endif
5399
5400#ifndef coff_bfd_set_private_flags
5401#define coff_bfd_set_private_flags _bfd_generic_bfd_set_private_flags
5402#endif
5403
e60b52c6 5404#ifndef coff_bfd_print_private_bfd_data
252b5132
RH
5405#define coff_bfd_print_private_bfd_data _bfd_generic_bfd_print_private_bfd_data
5406#endif
5407
5408#ifndef coff_bfd_is_local_label_name
5409#define coff_bfd_is_local_label_name _bfd_coff_is_local_label_name
5410#endif
5411
3c9458e9
NC
5412#ifndef coff_bfd_is_target_special_symbol
5413#define coff_bfd_is_target_special_symbol ((bfd_boolean (*) (bfd *, asymbol *)) bfd_false)
5414#endif
5415
252b5132
RH
5416#ifndef coff_read_minisymbols
5417#define coff_read_minisymbols _bfd_generic_read_minisymbols
5418#endif
5419
5420#ifndef coff_minisymbol_to_symbol
5421#define coff_minisymbol_to_symbol _bfd_generic_minisymbol_to_symbol
5422#endif
5423
5424/* The reloc lookup routine must be supplied by each individual COFF
5425 backend. */
5426#ifndef coff_bfd_reloc_type_lookup
5427#define coff_bfd_reloc_type_lookup _bfd_norelocs_bfd_reloc_type_lookup
5428#endif
157090f7
AM
5429#ifndef coff_bfd_reloc_name_lookup
5430#define coff_bfd_reloc_name_lookup _bfd_norelocs_bfd_reloc_name_lookup
5431#endif
252b5132
RH
5432
5433#ifndef coff_bfd_get_relocated_section_contents
5434#define coff_bfd_get_relocated_section_contents \
5435 bfd_generic_get_relocated_section_contents
5436#endif
5437
5438#ifndef coff_bfd_relax_section
5439#define coff_bfd_relax_section bfd_generic_relax_section
5440#endif
5441
5442#ifndef coff_bfd_gc_sections
5443#define coff_bfd_gc_sections bfd_generic_gc_sections
5444#endif
c3c89269 5445
8550eb6e
JJ
5446#ifndef coff_bfd_merge_sections
5447#define coff_bfd_merge_sections bfd_generic_merge_sections
5448#endif
5449
72adc230
AM
5450#ifndef coff_bfd_is_group_section
5451#define coff_bfd_is_group_section bfd_generic_is_group_section
5452#endif
5453
e61463e1
AM
5454#ifndef coff_bfd_discard_group
5455#define coff_bfd_discard_group bfd_generic_discard_group
5456#endif
5457
082b7297
L
5458#ifndef coff_section_already_linked
5459#define coff_section_already_linked \
5460 _bfd_generic_section_already_linked
5461#endif
5462
3fa78519 5463#define CREATE_BIG_COFF_TARGET_VEC(VAR, NAME, EXTRA_O_FLAGS, EXTRA_S_FLAGS, UNDER, ALTERNATIVE, SWAP_TABLE) \
4c117b10
ILT
5464const bfd_target VAR = \
5465{ \
5466 NAME , \
5467 bfd_target_coff_flavour, \
7920ce38
NC
5468 BFD_ENDIAN_BIG, /* Data byte order is big. */ \
5469 BFD_ENDIAN_BIG, /* Header byte order is big. */ \
4c117b10
ILT
5470 /* object flags */ \
5471 (HAS_RELOC | EXEC_P | HAS_LINENO | HAS_DEBUG | \
5472 HAS_SYMS | HAS_LOCALS | WP_TEXT | EXTRA_O_FLAGS), \
5473 /* section flags */ \
5474 (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC | EXTRA_S_FLAGS),\
7920ce38
NC
5475 UNDER, /* Leading symbol underscore. */ \
5476 '/', /* AR_pad_char. */ \
5477 15, /* AR_max_namelen. */ \
4c117b10
ILT
5478 \
5479 /* Data conversion functions. */ \
5480 bfd_getb64, bfd_getb_signed_64, bfd_putb64, \
5481 bfd_getb32, bfd_getb_signed_32, bfd_putb32, \
5482 bfd_getb16, bfd_getb_signed_16, bfd_putb16, \
5483 \
5484 /* Header conversion functions. */ \
5485 bfd_getb64, bfd_getb_signed_64, bfd_putb64, \
5486 bfd_getb32, bfd_getb_signed_32, bfd_putb32, \
5487 bfd_getb16, bfd_getb_signed_16, bfd_putb16, \
5488 \
7920ce38 5489 /* bfd_check_format. */ \
4c117b10
ILT
5490 { _bfd_dummy_target, coff_object_p, bfd_generic_archive_p, \
5491 _bfd_dummy_target }, \
7920ce38 5492 /* bfd_set_format. */ \
4c117b10 5493 { bfd_false, coff_mkobject, _bfd_generic_mkarchive, bfd_false }, \
7920ce38 5494 /* bfd_write_contents. */ \
4c117b10
ILT
5495 { bfd_false, coff_write_object_contents, _bfd_write_archive_contents, \
5496 bfd_false }, \
5497 \
5498 BFD_JUMP_TABLE_GENERIC (coff), \
5499 BFD_JUMP_TABLE_COPY (coff), \
5500 BFD_JUMP_TABLE_CORE (_bfd_nocore), \
5501 BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_coff), \
5502 BFD_JUMP_TABLE_SYMBOLS (coff), \
5503 BFD_JUMP_TABLE_RELOCS (coff), \
5504 BFD_JUMP_TABLE_WRITE (coff), \
5505 BFD_JUMP_TABLE_LINK (coff), \
5506 BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic), \
5507 \
5508 ALTERNATIVE, \
5509 \
3fa78519 5510 SWAP_TABLE \
c3c89269
NC
5511};
5512
3fa78519
SS
5513#define CREATE_BIGHDR_COFF_TARGET_VEC(VAR, NAME, EXTRA_O_FLAGS, EXTRA_S_FLAGS, UNDER, ALTERNATIVE, SWAP_TABLE) \
5514const bfd_target VAR = \
5515{ \
5516 NAME , \
5517 bfd_target_coff_flavour, \
7920ce38
NC
5518 BFD_ENDIAN_LITTLE, /* Data byte order is little. */ \
5519 BFD_ENDIAN_BIG, /* Header byte order is big. */ \
3fa78519
SS
5520 /* object flags */ \
5521 (HAS_RELOC | EXEC_P | HAS_LINENO | HAS_DEBUG | \
5522 HAS_SYMS | HAS_LOCALS | WP_TEXT | EXTRA_O_FLAGS), \
5523 /* section flags */ \
5524 (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC | EXTRA_S_FLAGS),\
7920ce38
NC
5525 UNDER, /* Leading symbol underscore. */ \
5526 '/', /* AR_pad_char. */ \
5527 15, /* AR_max_namelen. */ \
3fa78519
SS
5528 \
5529 /* Data conversion functions. */ \
5530 bfd_getb64, bfd_getb_signed_64, bfd_putb64, \
5531 bfd_getb32, bfd_getb_signed_32, bfd_putb32, \
5532 bfd_getb16, bfd_getb_signed_16, bfd_putb16, \
5533 \
5534 /* Header conversion functions. */ \
5535 bfd_getb64, bfd_getb_signed_64, bfd_putb64, \
5536 bfd_getb32, bfd_getb_signed_32, bfd_putb32, \
5537 bfd_getb16, bfd_getb_signed_16, bfd_putb16, \
5538 \
7920ce38 5539 /* bfd_check_format. */ \
3fa78519
SS
5540 { _bfd_dummy_target, coff_object_p, bfd_generic_archive_p, \
5541 _bfd_dummy_target }, \
7920ce38 5542 /* bfd_set_format. */ \
3fa78519 5543 { bfd_false, coff_mkobject, _bfd_generic_mkarchive, bfd_false }, \
7920ce38 5544 /* bfd_write_contents. */ \
3fa78519
SS
5545 { bfd_false, coff_write_object_contents, _bfd_write_archive_contents, \
5546 bfd_false }, \
5547 \
5548 BFD_JUMP_TABLE_GENERIC (coff), \
5549 BFD_JUMP_TABLE_COPY (coff), \
5550 BFD_JUMP_TABLE_CORE (_bfd_nocore), \
5551 BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_coff), \
5552 BFD_JUMP_TABLE_SYMBOLS (coff), \
5553 BFD_JUMP_TABLE_RELOCS (coff), \
5554 BFD_JUMP_TABLE_WRITE (coff), \
5555 BFD_JUMP_TABLE_LINK (coff), \
5556 BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic), \
5557 \
5558 ALTERNATIVE, \
5559 \
5560 SWAP_TABLE \
5561};
5562
5563#define CREATE_LITTLE_COFF_TARGET_VEC(VAR, NAME, EXTRA_O_FLAGS, EXTRA_S_FLAGS, UNDER, ALTERNATIVE, SWAP_TABLE) \
4c117b10
ILT
5564const bfd_target VAR = \
5565{ \
5566 NAME , \
5567 bfd_target_coff_flavour, \
7920ce38
NC
5568 BFD_ENDIAN_LITTLE, /* Data byte order is little. */ \
5569 BFD_ENDIAN_LITTLE, /* Header byte order is little. */ \
4c117b10
ILT
5570 /* object flags */ \
5571 (HAS_RELOC | EXEC_P | HAS_LINENO | HAS_DEBUG | \
5572 HAS_SYMS | HAS_LOCALS | WP_TEXT | EXTRA_O_FLAGS), \
5573 /* section flags */ \
5574 (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC | EXTRA_S_FLAGS),\
7920ce38
NC
5575 UNDER, /* Leading symbol underscore. */ \
5576 '/', /* AR_pad_char. */ \
5577 15, /* AR_max_namelen. */ \
4c117b10
ILT
5578 \
5579 /* Data conversion functions. */ \
5580 bfd_getl64, bfd_getl_signed_64, bfd_putl64, \
5581 bfd_getl32, bfd_getl_signed_32, bfd_putl32, \
5582 bfd_getl16, bfd_getl_signed_16, bfd_putl16, \
5583 /* Header conversion functions. */ \
5584 bfd_getl64, bfd_getl_signed_64, bfd_putl64, \
5585 bfd_getl32, bfd_getl_signed_32, bfd_putl32, \
5586 bfd_getl16, bfd_getl_signed_16, bfd_putl16, \
7920ce38 5587 /* bfd_check_format. */ \
4c117b10
ILT
5588 { _bfd_dummy_target, coff_object_p, bfd_generic_archive_p, \
5589 _bfd_dummy_target }, \
7920ce38 5590 /* bfd_set_format. */ \
4c117b10 5591 { bfd_false, coff_mkobject, _bfd_generic_mkarchive, bfd_false }, \
7920ce38 5592 /* bfd_write_contents. */ \
4c117b10
ILT
5593 { bfd_false, coff_write_object_contents, _bfd_write_archive_contents, \
5594 bfd_false }, \
5595 \
5596 BFD_JUMP_TABLE_GENERIC (coff), \
5597 BFD_JUMP_TABLE_COPY (coff), \
5598 BFD_JUMP_TABLE_CORE (_bfd_nocore), \
5599 BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_coff), \
5600 BFD_JUMP_TABLE_SYMBOLS (coff), \
5601 BFD_JUMP_TABLE_RELOCS (coff), \
5602 BFD_JUMP_TABLE_WRITE (coff), \
5603 BFD_JUMP_TABLE_LINK (coff), \
5604 BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic), \
5605 \
5606 ALTERNATIVE, \
5607 \
3fa78519 5608 SWAP_TABLE \
c3c89269 5609};
This page took 0.972191 seconds and 4 git commands to generate.