merge from gcc
[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,
157090f7 3 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007
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
RH
1294.
1295.} bfd_coff_backend_data;
1296.
dc810e39
AM
1297.#define coff_backend_info(abfd) \
1298. ((bfd_coff_backend_data *) (abfd)->xvec->backend_data)
252b5132
RH
1299.
1300.#define bfd_coff_swap_aux_in(a,e,t,c,ind,num,i) \
dc810e39 1301. ((coff_backend_info (a)->_bfd_coff_swap_aux_in) (a,e,t,c,ind,num,i))
252b5132
RH
1302.
1303.#define bfd_coff_swap_sym_in(a,e,i) \
dc810e39 1304. ((coff_backend_info (a)->_bfd_coff_swap_sym_in) (a,e,i))
252b5132
RH
1305.
1306.#define bfd_coff_swap_lineno_in(a,e,i) \
dc810e39 1307. ((coff_backend_info ( a)->_bfd_coff_swap_lineno_in) (a,e,i))
252b5132
RH
1308.
1309.#define bfd_coff_swap_reloc_out(abfd, i, o) \
dc810e39 1310. ((coff_backend_info (abfd)->_bfd_coff_swap_reloc_out) (abfd, i, o))
252b5132
RH
1311.
1312.#define bfd_coff_swap_lineno_out(abfd, i, o) \
dc810e39 1313. ((coff_backend_info (abfd)->_bfd_coff_swap_lineno_out) (abfd, i, o))
252b5132
RH
1314.
1315.#define bfd_coff_swap_aux_out(a,i,t,c,ind,num,o) \
dc810e39 1316. ((coff_backend_info (a)->_bfd_coff_swap_aux_out) (a,i,t,c,ind,num,o))
252b5132
RH
1317.
1318.#define bfd_coff_swap_sym_out(abfd, i,o) \
dc810e39 1319. ((coff_backend_info (abfd)->_bfd_coff_swap_sym_out) (abfd, i, o))
252b5132
RH
1320.
1321.#define bfd_coff_swap_scnhdr_out(abfd, i,o) \
dc810e39 1322. ((coff_backend_info (abfd)->_bfd_coff_swap_scnhdr_out) (abfd, i, o))
252b5132
RH
1323.
1324.#define bfd_coff_swap_filehdr_out(abfd, i,o) \
dc810e39 1325. ((coff_backend_info (abfd)->_bfd_coff_swap_filehdr_out) (abfd, i, o))
252b5132
RH
1326.
1327.#define bfd_coff_swap_aouthdr_out(abfd, i,o) \
dc810e39 1328. ((coff_backend_info (abfd)->_bfd_coff_swap_aouthdr_out) (abfd, i, o))
252b5132
RH
1329.
1330.#define bfd_coff_filhsz(abfd) (coff_backend_info (abfd)->_bfd_filhsz)
1331.#define bfd_coff_aoutsz(abfd) (coff_backend_info (abfd)->_bfd_aoutsz)
1332.#define bfd_coff_scnhsz(abfd) (coff_backend_info (abfd)->_bfd_scnhsz)
1333.#define bfd_coff_symesz(abfd) (coff_backend_info (abfd)->_bfd_symesz)
1334.#define bfd_coff_auxesz(abfd) (coff_backend_info (abfd)->_bfd_auxesz)
1335.#define bfd_coff_relsz(abfd) (coff_backend_info (abfd)->_bfd_relsz)
1336.#define bfd_coff_linesz(abfd) (coff_backend_info (abfd)->_bfd_linesz)
692b7d62 1337.#define bfd_coff_filnmlen(abfd) (coff_backend_info (abfd)->_bfd_filnmlen)
dc810e39
AM
1338.#define bfd_coff_long_filenames(abfd) \
1339. (coff_backend_info (abfd)->_bfd_coff_long_filenames)
252b5132 1340.#define bfd_coff_long_section_names(abfd) \
dc810e39 1341. (coff_backend_info (abfd)->_bfd_coff_long_section_names)
252b5132 1342.#define bfd_coff_default_section_alignment_power(abfd) \
dc810e39 1343. (coff_backend_info (abfd)->_bfd_coff_default_section_alignment_power)
252b5132 1344.#define bfd_coff_swap_filehdr_in(abfd, i,o) \
dc810e39 1345. ((coff_backend_info (abfd)->_bfd_coff_swap_filehdr_in) (abfd, i, o))
252b5132
RH
1346.
1347.#define bfd_coff_swap_aouthdr_in(abfd, i,o) \
dc810e39 1348. ((coff_backend_info (abfd)->_bfd_coff_swap_aouthdr_in) (abfd, i, o))
252b5132
RH
1349.
1350.#define bfd_coff_swap_scnhdr_in(abfd, i,o) \
dc810e39 1351. ((coff_backend_info (abfd)->_bfd_coff_swap_scnhdr_in) (abfd, i, o))
252b5132
RH
1352.
1353.#define bfd_coff_swap_reloc_in(abfd, i, o) \
dc810e39 1354. ((coff_backend_info (abfd)->_bfd_coff_swap_reloc_in) (abfd, i, o))
252b5132
RH
1355.
1356.#define bfd_coff_bad_format_hook(abfd, filehdr) \
dc810e39 1357. ((coff_backend_info (abfd)->_bfd_coff_bad_format_hook) (abfd, filehdr))
252b5132
RH
1358.
1359.#define bfd_coff_set_arch_mach_hook(abfd, filehdr)\
dc810e39 1360. ((coff_backend_info (abfd)->_bfd_coff_set_arch_mach_hook) (abfd, filehdr))
252b5132 1361.#define bfd_coff_mkobject_hook(abfd, filehdr, aouthdr)\
ed781d5d
NC
1362. ((coff_backend_info (abfd)->_bfd_coff_mkobject_hook)\
1363. (abfd, filehdr, aouthdr))
252b5132 1364.
7c8ca0e4 1365.#define bfd_coff_styp_to_sec_flags_hook(abfd, scnhdr, name, section, flags_ptr)\
dc810e39
AM
1366. ((coff_backend_info (abfd)->_bfd_styp_to_sec_flags_hook)\
1367. (abfd, scnhdr, name, section, flags_ptr))
252b5132
RH
1368.
1369.#define bfd_coff_set_alignment_hook(abfd, sec, scnhdr)\
dc810e39 1370. ((coff_backend_info (abfd)->_bfd_set_alignment_hook) (abfd, sec, scnhdr))
252b5132
RH
1371.
1372.#define bfd_coff_slurp_symbol_table(abfd)\
dc810e39 1373. ((coff_backend_info (abfd)->_bfd_coff_slurp_symbol_table) (abfd))
252b5132
RH
1374.
1375.#define bfd_coff_symname_in_debug(abfd, sym)\
dc810e39 1376. ((coff_backend_info (abfd)->_bfd_coff_symname_in_debug) (abfd, sym))
252b5132 1377.
2243c419 1378.#define bfd_coff_force_symnames_in_strings(abfd)\
dc810e39 1379. (coff_backend_info (abfd)->_bfd_coff_force_symnames_in_strings)
2243c419
CP
1380.
1381.#define bfd_coff_debug_string_prefix_length(abfd)\
dc810e39 1382. (coff_backend_info (abfd)->_bfd_coff_debug_string_prefix_length)
2243c419 1383.
252b5132 1384.#define bfd_coff_print_aux(abfd, file, base, symbol, aux, indaux)\
dc810e39
AM
1385. ((coff_backend_info (abfd)->_bfd_coff_print_aux)\
1386. (abfd, file, base, symbol, aux, indaux))
252b5132 1387.
ed781d5d
NC
1388.#define bfd_coff_reloc16_extra_cases(abfd, link_info, link_order,\
1389. reloc, data, src_ptr, dst_ptr)\
dc810e39
AM
1390. ((coff_backend_info (abfd)->_bfd_coff_reloc16_extra_cases)\
1391. (abfd, link_info, link_order, reloc, data, src_ptr, dst_ptr))
252b5132
RH
1392.
1393.#define bfd_coff_reloc16_estimate(abfd, section, reloc, shrink, link_info)\
dc810e39
AM
1394. ((coff_backend_info (abfd)->_bfd_coff_reloc16_estimate)\
1395. (abfd, section, reloc, shrink, link_info))
252b5132 1396.
5d54c628 1397.#define bfd_coff_classify_symbol(abfd, sym)\
dc810e39
AM
1398. ((coff_backend_info (abfd)->_bfd_coff_classify_symbol)\
1399. (abfd, sym))
252b5132
RH
1400.
1401.#define bfd_coff_compute_section_file_positions(abfd)\
dc810e39
AM
1402. ((coff_backend_info (abfd)->_bfd_coff_compute_section_file_positions)\
1403. (abfd))
252b5132
RH
1404.
1405.#define bfd_coff_start_final_link(obfd, info)\
dc810e39
AM
1406. ((coff_backend_info (obfd)->_bfd_coff_start_final_link)\
1407. (obfd, info))
252b5132 1408.#define bfd_coff_relocate_section(obfd,info,ibfd,o,con,rel,isyms,secs)\
dc810e39
AM
1409. ((coff_backend_info (ibfd)->_bfd_coff_relocate_section)\
1410. (obfd, info, ibfd, o, con, rel, isyms, secs))
252b5132 1411.#define bfd_coff_rtype_to_howto(abfd, sec, rel, h, sym, addendp)\
dc810e39
AM
1412. ((coff_backend_info (abfd)->_bfd_coff_rtype_to_howto)\
1413. (abfd, sec, rel, h, sym, addendp))
252b5132 1414.#define bfd_coff_adjust_symndx(obfd, info, ibfd, sec, rel, adjustedp)\
dc810e39
AM
1415. ((coff_backend_info (abfd)->_bfd_coff_adjust_symndx)\
1416. (obfd, info, ibfd, sec, rel, adjustedp))
ed781d5d
NC
1417.#define bfd_coff_link_add_one_symbol(info, abfd, name, flags, section,\
1418. value, string, cp, coll, hashp)\
dc810e39
AM
1419. ((coff_backend_info (abfd)->_bfd_coff_link_add_one_symbol)\
1420. (info, abfd, name, flags, section, value, string, cp, coll, hashp))
252b5132
RH
1421.
1422.#define bfd_coff_link_output_has_begun(a,p) \
7920ce38 1423. ((coff_backend_info (a)->_bfd_coff_link_output_has_begun) (a, p))
252b5132 1424.#define bfd_coff_final_link_postscript(a,p) \
7920ce38 1425. ((coff_backend_info (a)->_bfd_coff_final_link_postscript) (a, p))
252b5132
RH
1426.
1427*/
1428
1429/* See whether the magic number matches. */
1430
b34976b6 1431static bfd_boolean
7920ce38 1432coff_bad_format_hook (bfd * abfd ATTRIBUTE_UNUSED, void * filehdr)
252b5132
RH
1433{
1434 struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1435
1436 if (BADMAG (*internal_f))
b34976b6 1437 return FALSE;
252b5132 1438
ed781d5d 1439 /* If the optional header is NULL or not the correct size then
252b5132
RH
1440 quit; the only difference I can see between m88k dgux headers (MC88DMAGIC)
1441 and Intel 960 readwrite headers (I960WRMAGIC) is that the
1442 optional header is of a different size.
1443
1444 But the mips keeps extra stuff in it's opthdr, so dont check
ed781d5d 1445 when doing that. */
252b5132
RH
1446
1447#if defined(M88) || defined(I960)
6b3b007b 1448 if (internal_f->f_opthdr != 0 && bfd_coff_aoutsz (abfd) != internal_f->f_opthdr)
b34976b6 1449 return FALSE;
252b5132
RH
1450#endif
1451
b34976b6 1452 return TRUE;
252b5132
RH
1453}
1454
5a5b9651
SS
1455#ifdef TICOFF
1456static bfd_boolean
7920ce38 1457ticoff0_bad_format_hook (bfd *abfd ATTRIBUTE_UNUSED, void * filehdr)
5a5b9651
SS
1458{
1459 struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1460
1461 if (COFF0_BADMAG (*internal_f))
1462 return FALSE;
1463
1464 return TRUE;
1465}
1466#endif
1467
1468#ifdef TICOFF
1469static bfd_boolean
7920ce38 1470ticoff1_bad_format_hook (bfd *abfd ATTRIBUTE_UNUSED, void * filehdr)
5a5b9651
SS
1471{
1472 struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1473
1474 if (COFF1_BADMAG (*internal_f))
1475 return FALSE;
1476
1477 return TRUE;
1478}
1479#endif
1480
5dccc1dd
ILT
1481/* Check whether this section uses an alignment other than the
1482 default. */
1483
1484static void
7920ce38
NC
1485coff_set_custom_section_alignment (bfd *abfd ATTRIBUTE_UNUSED,
1486 asection *section,
1487 const struct coff_section_alignment_entry *alignment_table,
1488 const unsigned int table_size)
5dccc1dd
ILT
1489{
1490 const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1491 unsigned int i;
1492
1493 for (i = 0; i < table_size; ++i)
1494 {
1495 const char *secname = bfd_get_section_name (abfd, section);
ed781d5d 1496
5dccc1dd
ILT
1497 if (alignment_table[i].comparison_length == (unsigned int) -1
1498 ? strcmp (alignment_table[i].name, secname) == 0
1499 : strncmp (alignment_table[i].name, secname,
1500 alignment_table[i].comparison_length) == 0)
1501 break;
1502 }
1503 if (i >= table_size)
1504 return;
1505
1506 if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1507 && default_alignment < alignment_table[i].default_alignment_min)
1508 return;
1509
1510 if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1e738b87
NC
1511#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1512 && default_alignment > alignment_table[i].default_alignment_max
1513#endif
1514 )
5dccc1dd
ILT
1515 return;
1516
1517 section->alignment_power = alignment_table[i].alignment_power;
1518}
1519
1520/* Custom section alignment records. */
1521
1522static const struct coff_section_alignment_entry
1523coff_section_alignment_table[] =
1524{
1525#ifdef COFF_SECTION_ALIGNMENT_ENTRIES
1526 COFF_SECTION_ALIGNMENT_ENTRIES,
1527#endif
1528 /* There must not be any gaps between .stabstr sections. */
1529 { COFF_SECTION_NAME_PARTIAL_MATCH (".stabstr"),
1530 1, COFF_ALIGNMENT_FIELD_EMPTY, 0 },
1531 /* The .stab section must be aligned to 2**2 at most, to avoid gaps. */
1532 { COFF_SECTION_NAME_PARTIAL_MATCH (".stab"),
1533 3, COFF_ALIGNMENT_FIELD_EMPTY, 2 },
1534 /* Similarly for the .ctors and .dtors sections. */
1535 { COFF_SECTION_NAME_EXACT_MATCH (".ctors"),
1536 3, COFF_ALIGNMENT_FIELD_EMPTY, 2 },
1537 { COFF_SECTION_NAME_EXACT_MATCH (".dtors"),
1538 3, COFF_ALIGNMENT_FIELD_EMPTY, 2 }
1539};
1540
1541static const unsigned int coff_section_alignment_table_size =
1542 sizeof coff_section_alignment_table / sizeof coff_section_alignment_table[0];
1543
1544/* Initialize a section structure with information peculiar to this
1545 particular implementation of COFF. */
252b5132 1546
b34976b6 1547static bfd_boolean
7920ce38 1548coff_new_section_hook (bfd * abfd, asection * section)
252b5132
RH
1549{
1550 combined_entry_type *native;
dc810e39 1551 bfd_size_type amt;
252b5132
RH
1552
1553 section->alignment_power = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1554
1555#ifdef RS6000COFF_C
eb1e0e80 1556 if (bfd_xcoff_text_align_power (abfd) != 0
252b5132 1557 && strcmp (bfd_get_section_name (abfd, section), ".text") == 0)
eb1e0e80
NC
1558 section->alignment_power = bfd_xcoff_text_align_power (abfd);
1559 if (bfd_xcoff_data_align_power (abfd) != 0
252b5132 1560 && strcmp (bfd_get_section_name (abfd, section), ".data") == 0)
eb1e0e80 1561 section->alignment_power = bfd_xcoff_data_align_power (abfd);
252b5132
RH
1562#endif
1563
f592407e
AM
1564 /* Set up the section symbol. */
1565 if (!_bfd_generic_new_section_hook (abfd, section))
1566 return FALSE;
1567
252b5132
RH
1568 /* Allocate aux records for section symbols, to store size and
1569 related info.
1570
1571 @@ The 10 is a guess at a plausible maximum number of aux entries
1572 (but shouldn't be a constant). */
dc810e39 1573 amt = sizeof (combined_entry_type) * 10;
7920ce38 1574 native = bfd_zalloc (abfd, amt);
252b5132 1575 if (native == NULL)
b34976b6 1576 return FALSE;
252b5132
RH
1577
1578 /* We don't need to set up n_name, n_value, or n_scnum in the native
5c4491d3 1579 symbol information, since they'll be overridden by the BFD symbol
252b5132
RH
1580 anyhow. However, we do need to set the type and storage class,
1581 in case this symbol winds up getting written out. The value 0
1582 for n_numaux is already correct. */
1583
1584 native->u.syment.n_type = T_NULL;
1585 native->u.syment.n_sclass = C_STAT;
1586
1587 coffsymbol (section->symbol)->native = native;
1588
5dccc1dd
ILT
1589 coff_set_custom_section_alignment (abfd, section,
1590 coff_section_alignment_table,
1591 coff_section_alignment_table_size);
252b5132 1592
b34976b6 1593 return TRUE;
252b5132
RH
1594}
1595
1596#ifdef COFF_ALIGN_IN_SECTION_HEADER
1597
1598/* Set the alignment of a BFD section. */
1599
252b5132 1600static void
7920ce38
NC
1601coff_set_alignment_hook (bfd * abfd ATTRIBUTE_UNUSED,
1602 asection * section,
1603 void * scnhdr)
252b5132
RH
1604{
1605 struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1606 unsigned int i;
1607
1608#ifdef I960
ed781d5d 1609 /* Extract ALIGN from 2**ALIGN stored in section header. */
252b5132
RH
1610 for (i = 0; i < 32; i++)
1611 if ((1 << i) >= hdr->s_align)
1612 break;
1613#endif
1614#ifdef TIC80COFF
ed781d5d 1615 /* TI tools puts the alignment power in bits 8-11. */
252b5132 1616 i = (hdr->s_flags >> 8) & 0xF ;
81635ce4
TW
1617#endif
1618#ifdef COFF_DECODE_ALIGNMENT
1619 i = COFF_DECODE_ALIGNMENT(hdr->s_flags);
252b5132
RH
1620#endif
1621 section->alignment_power = i;
b9af77f5
TW
1622
1623#ifdef coff_set_section_load_page
1624 coff_set_section_load_page (section, hdr->s_page);
1625#endif
252b5132
RH
1626}
1627
1628#else /* ! COFF_ALIGN_IN_SECTION_HEADER */
1629#ifdef COFF_WITH_PE
1630
ed781d5d 1631/* A couple of macros to help setting the alignment power field. */
7920ce38
NC
1632#define ALIGN_SET(field, x, y) \
1633 if (((field) & IMAGE_SCN_ALIGN_64BYTES) == x)\
1634 {\
1635 section->alignment_power = y;\
1636 }
252b5132 1637
7920ce38
NC
1638#define ELIFALIGN_SET(field, x, y) \
1639 else if (((field) & IMAGE_SCN_ALIGN_64BYTES) == x) \
1640 {\
1641 section->alignment_power = y;\
1642 }
252b5132
RH
1643
1644static void
7920ce38
NC
1645coff_set_alignment_hook (bfd * abfd ATTRIBUTE_UNUSED,
1646 asection * section,
1647 void * scnhdr)
252b5132
RH
1648{
1649 struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
dc810e39 1650 bfd_size_type amt;
252b5132
RH
1651
1652 ALIGN_SET (hdr->s_flags, IMAGE_SCN_ALIGN_64BYTES, 6)
1653 ELIFALIGN_SET (hdr->s_flags, IMAGE_SCN_ALIGN_32BYTES, 5)
1654 ELIFALIGN_SET (hdr->s_flags, IMAGE_SCN_ALIGN_16BYTES, 4)
1655 ELIFALIGN_SET (hdr->s_flags, IMAGE_SCN_ALIGN_8BYTES, 3)
1656 ELIFALIGN_SET (hdr->s_flags, IMAGE_SCN_ALIGN_4BYTES, 2)
1657 ELIFALIGN_SET (hdr->s_flags, IMAGE_SCN_ALIGN_2BYTES, 1)
1658 ELIFALIGN_SET (hdr->s_flags, IMAGE_SCN_ALIGN_1BYTES, 0)
1659
252b5132 1660 /* In a PE image file, the s_paddr field holds the virtual size of a
8d3ad4e1
ILT
1661 section, while the s_size field holds the raw size. We also keep
1662 the original section flag value, since not every bit can be
1663 mapped onto a generic BFD section bit. */
1664 if (coff_section_data (abfd, section) == NULL)
252b5132 1665 {
dc810e39 1666 amt = sizeof (struct coff_section_tdata);
7920ce38 1667 section->used_by_bfd = bfd_zalloc (abfd, amt);
8d3ad4e1 1668 if (section->used_by_bfd == NULL)
7920ce38
NC
1669 /* FIXME: Return error. */
1670 abort ();
8d3ad4e1 1671 }
7920ce38 1672
8d3ad4e1
ILT
1673 if (pei_section_data (abfd, section) == NULL)
1674 {
dc810e39 1675 amt = sizeof (struct pei_section_tdata);
7920ce38 1676 coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
8d3ad4e1 1677 if (coff_section_data (abfd, section)->tdata == NULL)
7920ce38
NC
1678 /* FIXME: Return error. */
1679 abort ();
252b5132 1680 }
8d3ad4e1
ILT
1681 pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1682 pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
252b5132 1683
9d8cefa9 1684 section->lma = hdr->s_vaddr;
3e4554a2 1685
ed781d5d 1686 /* Check for extended relocs. */
3e4554a2
DD
1687 if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1688 {
1689 struct external_reloc dst;
1690 struct internal_reloc n;
dc810e39 1691 file_ptr oldpos = bfd_tell (abfd);
cd339148
NS
1692 bfd_size_type relsz = bfd_coff_relsz (abfd);
1693
dc810e39 1694 bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0);
7920ce38 1695 if (bfd_bread (& dst, relsz, abfd) != relsz)
3e4554a2 1696 return;
e60b52c6 1697
3e4554a2
DD
1698 coff_swap_reloc_in (abfd, &dst, &n);
1699 bfd_seek (abfd, oldpos, 0);
cd339148
NS
1700 section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1701 section->rel_filepos += relsz;
3e4554a2 1702 }
cd339148
NS
1703 else if (hdr->s_nreloc == 0xffff)
1704 (*_bfd_error_handler)
1705 ("%s: warning: claims to have 0xffff relocs, without overflow",
1706 bfd_get_filename (abfd));
252b5132
RH
1707}
1708#undef ALIGN_SET
1709#undef ELIFALIGN_SET
1710
1711#else /* ! COFF_WITH_PE */
1712#ifdef RS6000COFF_C
1713
1714/* We grossly abuse this function to handle XCOFF overflow headers.
1715 When we see one, we correct the reloc and line number counts in the
1716 real header, and remove the section we just created. */
1717
252b5132 1718static void
7920ce38 1719coff_set_alignment_hook (bfd *abfd, asection *section, void * scnhdr)
252b5132
RH
1720{
1721 struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1722 asection *real_sec;
252b5132
RH
1723
1724 if ((hdr->s_flags & STYP_OVRFLO) == 0)
1725 return;
1726
dc810e39 1727 real_sec = coff_section_from_bfd_index (abfd, (int) hdr->s_nreloc);
252b5132
RH
1728 if (real_sec == NULL)
1729 return;
1730
1731 real_sec->reloc_count = hdr->s_paddr;
1732 real_sec->lineno_count = hdr->s_vaddr;
1733
5daa8fe7 1734 if (!bfd_section_removed_from_list (abfd, section))
252b5132 1735 {
5daa8fe7
L
1736 bfd_section_list_remove (abfd, section);
1737 --abfd->section_count;
252b5132
RH
1738 }
1739}
1740
1741#else /* ! RS6000COFF_C */
1742
1743#define coff_set_alignment_hook \
7920ce38 1744 ((void (*) (bfd *, asection *, void *)) bfd_void)
252b5132
RH
1745
1746#endif /* ! RS6000COFF_C */
1747#endif /* ! COFF_WITH_PE */
1748#endif /* ! COFF_ALIGN_IN_SECTION_HEADER */
1749
1750#ifndef coff_mkobject
1751
b34976b6 1752static bfd_boolean
7920ce38 1753coff_mkobject (bfd * abfd)
252b5132
RH
1754{
1755 coff_data_type *coff;
dc810e39 1756 bfd_size_type amt = sizeof (coff_data_type);
252b5132 1757
7920ce38
NC
1758 abfd->tdata.coff_obj_data = bfd_zalloc (abfd, amt);
1759 if (abfd->tdata.coff_obj_data == NULL)
b34976b6 1760 return FALSE;
252b5132 1761 coff = coff_data (abfd);
7920ce38
NC
1762 coff->symbols = NULL;
1763 coff->conversion_table = NULL;
1764 coff->raw_syments = NULL;
252b5132
RH
1765 coff->relocbase = 0;
1766 coff->local_toc_sym_map = 0;
1767
1768/* make_abs_section(abfd);*/
1769
b34976b6 1770 return TRUE;
252b5132
RH
1771}
1772#endif
1773
1774/* Create the COFF backend specific information. */
ed781d5d 1775
252b5132 1776#ifndef coff_mkobject_hook
7920ce38
NC
1777static void *
1778coff_mkobject_hook (bfd * abfd,
1779 void * filehdr,
1780 void * aouthdr ATTRIBUTE_UNUSED)
252b5132
RH
1781{
1782 struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1783 coff_data_type *coff;
1784
82e51918 1785 if (! coff_mkobject (abfd))
252b5132
RH
1786 return NULL;
1787
1788 coff = coff_data (abfd);
1789
1790 coff->sym_filepos = internal_f->f_symptr;
1791
1792 /* These members communicate important constants about the symbol
1793 table to GDB's symbol-reading code. These `constants'
1794 unfortunately vary among coff implementations... */
1795 coff->local_n_btmask = N_BTMASK;
1796 coff->local_n_btshft = N_BTSHFT;
1797 coff->local_n_tmask = N_TMASK;
1798 coff->local_n_tshift = N_TSHIFT;
6b3b007b
NC
1799 coff->local_symesz = bfd_coff_symesz (abfd);
1800 coff->local_auxesz = bfd_coff_auxesz (abfd);
1801 coff->local_linesz = bfd_coff_linesz (abfd);
252b5132 1802
1135238b
ILT
1803 coff->timestamp = internal_f->f_timdat;
1804
252b5132
RH
1805 obj_raw_syment_count (abfd) =
1806 obj_conv_table_size (abfd) =
1807 internal_f->f_nsyms;
1808
1809#ifdef RS6000COFF_C
1810 if ((internal_f->f_flags & F_SHROBJ) != 0)
1811 abfd->flags |= DYNAMIC;
6b3b007b 1812 if (aouthdr != NULL && internal_f->f_opthdr >= bfd_coff_aoutsz (abfd))
252b5132
RH
1813 {
1814 struct internal_aouthdr *internal_a =
1815 (struct internal_aouthdr *) aouthdr;
1816 struct xcoff_tdata *xcoff;
1817
1818 xcoff = xcoff_data (abfd);
a2fdf270
ND
1819# ifdef U803XTOCMAGIC
1820 xcoff->xcoff64 = internal_f->f_magic == U803XTOCMAGIC;
1821# else
1822 xcoff->xcoff64 = 0;
1823# endif
b34976b6 1824 xcoff->full_aouthdr = TRUE;
252b5132
RH
1825 xcoff->toc = internal_a->o_toc;
1826 xcoff->sntoc = internal_a->o_sntoc;
1827 xcoff->snentry = internal_a->o_snentry;
f3813499
TR
1828 bfd_xcoff_text_align_power (abfd) = internal_a->o_algntext;
1829 bfd_xcoff_data_align_power (abfd) = internal_a->o_algndata;
252b5132
RH
1830 xcoff->modtype = internal_a->o_modtype;
1831 xcoff->cputype = internal_a->o_cputype;
1832 xcoff->maxdata = internal_a->o_maxdata;
1833 xcoff->maxstack = internal_a->o_maxstack;
1834 }
1835#endif
1836
e60b52c6 1837#ifdef ARM
f13b834e 1838 /* Set the flags field from the COFF header read in. */
252b5132
RH
1839 if (! _bfd_coff_arm_set_private_flags (abfd, internal_f->f_flags))
1840 coff->flags = 0;
1841#endif
e60b52c6 1842
4cfec37b
ILT
1843#ifdef COFF_WITH_PE
1844 /* FIXME: I'm not sure this is ever executed, since peicode.h
1845 defines coff_mkobject_hook. */
1846 if ((internal_f->f_flags & IMAGE_FILE_DEBUG_STRIPPED) == 0)
1847 abfd->flags |= HAS_DEBUG;
1848#endif
1849
7920ce38 1850 return coff;
252b5132
RH
1851}
1852#endif
1853
1854/* Determine the machine architecture and type. FIXME: This is target
1855 dependent because the magic numbers are defined in the target
1856 dependent header files. But there is no particular need for this.
1857 If the magic numbers were moved to a separate file, this function
1858 would be target independent and would also be much more successful
1859 at linking together COFF files for different architectures. */
1860
b34976b6 1861static bfd_boolean
7920ce38 1862coff_set_arch_mach_hook (bfd *abfd, void * filehdr)
252b5132 1863{
dc810e39 1864 unsigned long machine;
252b5132
RH
1865 enum bfd_architecture arch;
1866 struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1867
250d94fd 1868 /* Zero selects the default machine for an arch. */
252b5132
RH
1869 machine = 0;
1870 switch (internal_f->f_magic)
1871 {
3b16e843
NC
1872#ifdef OR32_MAGIC_BIG
1873 case OR32_MAGIC_BIG:
1874 case OR32_MAGIC_LITTLE:
1875 arch = bfd_arch_or32;
3b16e843
NC
1876 break;
1877#endif
252b5132
RH
1878#ifdef PPCMAGIC
1879 case PPCMAGIC:
1880 arch = bfd_arch_powerpc;
e60b52c6 1881 break;
252b5132
RH
1882#endif
1883#ifdef I386MAGIC
1884 case I386MAGIC:
1885 case I386PTXMAGIC:
99ad8390
NC
1886 case I386AIXMAGIC: /* Danbury PS/2 AIX C Compiler. */
1887 case LYNXCOFFMAGIC: /* Shadows the m68k Lynx number below, sigh. */
252b5132 1888 arch = bfd_arch_i386;
252b5132
RH
1889 break;
1890#endif
99ad8390
NC
1891#ifdef AMD64MAGIC
1892 case AMD64MAGIC:
1893 arch = bfd_arch_i386;
1894 machine = bfd_mach_x86_64;
1895 break;
1896#endif
fac41780
JW
1897#ifdef IA64MAGIC
1898 case IA64MAGIC:
1899 arch = bfd_arch_ia64;
fac41780
JW
1900 break;
1901#endif
252b5132
RH
1902#ifdef ARMMAGIC
1903 case ARMMAGIC:
17505c5c
NC
1904 case ARMPEMAGIC:
1905 case THUMBPEMAGIC:
252b5132 1906 arch = bfd_arch_arm;
5a6c6817
NC
1907 machine = bfd_arm_get_mach_from_notes (abfd, ARM_NOTE_SECTION);
1908 if (machine == bfd_mach_arm_unknown)
252b5132 1909 {
5a6c6817
NC
1910 switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
1911 {
1912 case F_ARM_2: machine = bfd_mach_arm_2; break;
1913 case F_ARM_2a: machine = bfd_mach_arm_2a; break;
1914 case F_ARM_3: machine = bfd_mach_arm_3; break;
1915 default:
1916 case F_ARM_3M: machine = bfd_mach_arm_3M; break;
1917 case F_ARM_4: machine = bfd_mach_arm_4; break;
1918 case F_ARM_4T: machine = bfd_mach_arm_4T; break;
1919 /* The COFF header does not have enough bits available
1920 to cover all the different ARM architectures. So
1921 we interpret F_ARM_5, the highest flag value to mean
1922 "the highest ARM architecture known to BFD" which is
1923 currently the XScale. */
1924 case F_ARM_5: machine = bfd_mach_arm_XScale; break;
1925 }
252b5132
RH
1926 }
1927 break;
1928#endif
1929#ifdef MC68MAGIC
1930 case MC68MAGIC:
1931 case M68MAGIC:
1932#ifdef MC68KBCSMAGIC
1933 case MC68KBCSMAGIC:
1934#endif
1935#ifdef APOLLOM68KMAGIC
1936 case APOLLOM68KMAGIC:
1937#endif
1938#ifdef LYNXCOFFMAGIC
1939 case LYNXCOFFMAGIC:
1940#endif
1941 arch = bfd_arch_m68k;
1942 machine = bfd_mach_m68020;
1943 break;
1944#endif
7499d566
NC
1945#ifdef MAXQ20MAGIC
1946 case MAXQ20MAGIC:
1947 arch = bfd_arch_maxq;
5c4504f7
NC
1948 switch (internal_f->f_flags & F_MACHMASK)
1949 {
1950 case F_MAXQ10:
1951 machine = bfd_mach_maxq10;
1952 break;
1953 case F_MAXQ20:
1954 machine = bfd_mach_maxq20;
1955 break;
1956 default:
1957 return FALSE;
1958 }
7499d566
NC
1959 break;
1960#endif
252b5132
RH
1961#ifdef MC88MAGIC
1962 case MC88MAGIC:
1963 case MC88DMAGIC:
1964 case MC88OMAGIC:
1965 arch = bfd_arch_m88k;
1966 machine = 88100;
1967 break;
1968#endif
3c9b82ba
NC
1969#ifdef Z80MAGIC
1970 case Z80MAGIC:
1971 arch = bfd_arch_z80;
1972 switch (internal_f->f_flags & F_MACHMASK)
1973 {
1974 case 0:
1975 case bfd_mach_z80strict << 12:
1976 case bfd_mach_z80 << 12:
1977 case bfd_mach_z80full << 12:
1978 case bfd_mach_r800 << 12:
1979 machine = ((unsigned)internal_f->f_flags & F_MACHMASK) >> 12;
1980 break;
1981 default:
1982 return FALSE;
1983 }
1984 break;
1985#endif
252b5132
RH
1986#ifdef Z8KMAGIC
1987 case Z8KMAGIC:
1988 arch = bfd_arch_z8k;
1989 switch (internal_f->f_flags & F_MACHMASK)
1990 {
1991 case F_Z8001:
1992 machine = bfd_mach_z8001;
1993 break;
1994 case F_Z8002:
1995 machine = bfd_mach_z8002;
1996 break;
1997 default:
b34976b6 1998 return FALSE;
252b5132
RH
1999 }
2000 break;
2001#endif
2002#ifdef I860
2003 case I860MAGIC:
2004 arch = bfd_arch_i860;
2005 break;
2006#endif
2007#ifdef I960
2008#ifdef I960ROMAGIC
2009 case I960ROMAGIC:
2010 case I960RWMAGIC:
2011 arch = bfd_arch_i960;
2012 switch (F_I960TYPE & internal_f->f_flags)
2013 {
2014 default:
2015 case F_I960CORE:
2016 machine = bfd_mach_i960_core;
2017 break;
2018 case F_I960KB:
2019 machine = bfd_mach_i960_kb_sb;
2020 break;
2021 case F_I960MC:
2022 machine = bfd_mach_i960_mc;
2023 break;
2024 case F_I960XA:
2025 machine = bfd_mach_i960_xa;
2026 break;
2027 case F_I960CA:
2028 machine = bfd_mach_i960_ca;
2029 break;
2030 case F_I960KA:
2031 machine = bfd_mach_i960_ka_sa;
2032 break;
2033 case F_I960JX:
2034 machine = bfd_mach_i960_jx;
2035 break;
2036 case F_I960HX:
2037 machine = bfd_mach_i960_hx;
2038 break;
2039 }
2040 break;
2041#endif
2042#endif
2043
2044#ifdef RS6000COFF_C
7f6d05e8 2045#ifdef XCOFF64
eb1e0e80 2046 case U64_TOCMAGIC:
c6664dfb 2047 case U803XTOCMAGIC:
7f6d05e8 2048#else
252b5132
RH
2049 case U802ROMAGIC:
2050 case U802WRMAGIC:
2051 case U802TOCMAGIC:
7f6d05e8 2052#endif
252b5132
RH
2053 {
2054 int cputype;
2055
2056 if (xcoff_data (abfd)->cputype != -1)
2057 cputype = xcoff_data (abfd)->cputype & 0xff;
2058 else
2059 {
2060 /* We did not get a value from the a.out header. If the
2061 file has not been stripped, we may be able to get the
2062 architecture information from the first symbol, if it
2063 is a .file symbol. */
2064 if (obj_raw_syment_count (abfd) == 0)
2065 cputype = 0;
2066 else
2067 {
5ea1af0d 2068 bfd_byte *buf;
252b5132 2069 struct internal_syment sym;
dc810e39 2070 bfd_size_type amt = bfd_coff_symesz (abfd);
252b5132 2071
7920ce38 2072 buf = bfd_malloc (amt);
252b5132 2073 if (bfd_seek (abfd, obj_sym_filepos (abfd), SEEK_SET) != 0
dc810e39 2074 || bfd_bread (buf, amt, abfd) != amt)
5ea1af0d 2075 {
2fca4467 2076 free (buf);
b34976b6 2077 return FALSE;
5ea1af0d 2078 }
7920ce38 2079 bfd_coff_swap_sym_in (abfd, buf, & sym);
252b5132
RH
2080 if (sym.n_sclass == C_FILE)
2081 cputype = sym.n_type & 0xff;
2082 else
2083 cputype = 0;
2fca4467 2084 free (buf);
252b5132
RH
2085 }
2086 }
2087
2088 /* FIXME: We don't handle all cases here. */
2089 switch (cputype)
2090 {
2091 default:
2092 case 0:
beb1bf64
TR
2093 arch = bfd_xcoff_architecture (abfd);
2094 machine = bfd_xcoff_machine (abfd);
252b5132
RH
2095 break;
2096
2097 case 1:
2098 arch = bfd_arch_powerpc;
87f33987 2099 machine = bfd_mach_ppc_601;
252b5132
RH
2100 break;
2101 case 2: /* 64 bit PowerPC */
2102 arch = bfd_arch_powerpc;
87f33987 2103 machine = bfd_mach_ppc_620;
252b5132
RH
2104 break;
2105 case 3:
2106 arch = bfd_arch_powerpc;
87f33987 2107 machine = bfd_mach_ppc;
252b5132
RH
2108 break;
2109 case 4:
2110 arch = bfd_arch_rs6000;
87f33987 2111 machine = bfd_mach_rs6k;
252b5132
RH
2112 break;
2113 }
2114 }
2115 break;
2116#endif
2117
2118#ifdef WE32KMAGIC
2119 case WE32KMAGIC:
2120 arch = bfd_arch_we32k;
252b5132
RH
2121 break;
2122#endif
2123
2124#ifdef H8300MAGIC
2125 case H8300MAGIC:
2126 arch = bfd_arch_h8300;
2127 machine = bfd_mach_h8300;
8d9cd6b1 2128 /* !! FIXME this probably isn't the right place for this. */
252b5132
RH
2129 abfd->flags |= BFD_IS_RELAXABLE;
2130 break;
2131#endif
2132
2133#ifdef H8300HMAGIC
2134 case H8300HMAGIC:
2135 arch = bfd_arch_h8300;
2136 machine = bfd_mach_h8300h;
8d9cd6b1 2137 /* !! FIXME this probably isn't the right place for this. */
252b5132
RH
2138 abfd->flags |= BFD_IS_RELAXABLE;
2139 break;
2140#endif
2141
2142#ifdef H8300SMAGIC
2143 case H8300SMAGIC:
2144 arch = bfd_arch_h8300;
2145 machine = bfd_mach_h8300s;
8d9cd6b1
NC
2146 /* !! FIXME this probably isn't the right place for this. */
2147 abfd->flags |= BFD_IS_RELAXABLE;
2148 break;
2149#endif
2150
2151#ifdef H8300HNMAGIC
2152 case H8300HNMAGIC:
2153 arch = bfd_arch_h8300;
2154 machine = bfd_mach_h8300hn;
2155 /* !! FIXME this probably isn't the right place for this. */
2156 abfd->flags |= BFD_IS_RELAXABLE;
2157 break;
2158#endif
2159
2160#ifdef H8300SNMAGIC
2161 case H8300SNMAGIC:
2162 arch = bfd_arch_h8300;
2163 machine = bfd_mach_h8300sn;
2164 /* !! FIXME this probably isn't the right place for this. */
252b5132
RH
2165 abfd->flags |= BFD_IS_RELAXABLE;
2166 break;
2167#endif
2168
2169#ifdef SH_ARCH_MAGIC_BIG
2170 case SH_ARCH_MAGIC_BIG:
2171 case SH_ARCH_MAGIC_LITTLE:
17505c5c
NC
2172#ifdef COFF_WITH_PE
2173 case SH_ARCH_MAGIC_WINCE:
2174#endif
252b5132 2175 arch = bfd_arch_sh;
252b5132
RH
2176 break;
2177#endif
2178
17505c5c
NC
2179#ifdef MIPS_ARCH_MAGIC_WINCE
2180 case MIPS_ARCH_MAGIC_WINCE:
2181 arch = bfd_arch_mips;
17505c5c
NC
2182 break;
2183#endif
2184
252b5132
RH
2185#ifdef H8500MAGIC
2186 case H8500MAGIC:
2187 arch = bfd_arch_h8500;
252b5132
RH
2188 break;
2189#endif
2190
2191#ifdef SPARCMAGIC
2192 case SPARCMAGIC:
2193#ifdef LYNXCOFFMAGIC
2194 case LYNXCOFFMAGIC:
2195#endif
2196 arch = bfd_arch_sparc;
252b5132
RH
2197 break;
2198#endif
2199
2200#ifdef TIC30MAGIC
2201 case TIC30MAGIC:
2202 arch = bfd_arch_tic30;
2203 break;
2204#endif
2205
81635ce4
TW
2206#ifdef TICOFF0MAGIC
2207#ifdef TICOFF_TARGET_ARCH
ed781d5d 2208 /* This TI COFF section should be used by all new TI COFF v0 targets. */
81635ce4
TW
2209 case TICOFF0MAGIC:
2210 arch = TICOFF_TARGET_ARCH;
0da35f8b 2211 machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
81635ce4
TW
2212 break;
2213#endif
2214#endif
2215
2216#ifdef TICOFF1MAGIC
ed781d5d
NC
2217 /* This TI COFF section should be used by all new TI COFF v1/2 targets. */
2218 /* TI COFF1 and COFF2 use the target_id field to specify which arch. */
81635ce4
TW
2219 case TICOFF1MAGIC:
2220 case TICOFF2MAGIC:
2221 switch (internal_f->f_target_id)
2222 {
2223#ifdef TI_TARGET_ID
2224 case TI_TARGET_ID:
2225 arch = TICOFF_TARGET_ARCH;
0da35f8b 2226 machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
81635ce4
TW
2227 break;
2228#endif
2229 default:
4af1d5f6 2230 arch = bfd_arch_obscure;
81635ce4 2231 (*_bfd_error_handler)
e60b52c6 2232 (_("Unrecognized TI COFF target id '0x%x'"),
81635ce4
TW
2233 internal_f->f_target_id);
2234 break;
2235 }
2236 break;
2237#endif
2238
252b5132
RH
2239#ifdef TIC80_ARCH_MAGIC
2240 case TIC80_ARCH_MAGIC:
2241 arch = bfd_arch_tic80;
2242 break;
2243#endif
2244
2245#ifdef MCOREMAGIC
2246 case MCOREMAGIC:
2247 arch = bfd_arch_mcore;
2248 break;
2249#endif
c8e48751
AM
2250
2251#ifdef W65MAGIC
2252 case W65MAGIC:
2253 arch = bfd_arch_w65;
2254 break;
2255#endif
2256
ed781d5d 2257 default: /* Unreadable input file type. */
252b5132
RH
2258 arch = bfd_arch_obscure;
2259 break;
2260 }
2261
2262 bfd_default_set_arch_mach (abfd, arch, machine);
b34976b6 2263 return TRUE;
252b5132
RH
2264}
2265
2266#ifdef SYMNAME_IN_DEBUG
2267
b34976b6 2268static bfd_boolean
7920ce38 2269symname_in_debug_hook (bfd * abfd ATTRIBUTE_UNUSED, struct internal_syment *sym)
252b5132 2270{
82e51918 2271 return SYMNAME_IN_DEBUG (sym) != 0;
252b5132
RH
2272}
2273
2274#else
2275
2276#define symname_in_debug_hook \
7920ce38 2277 (bfd_boolean (*) (bfd *, struct internal_syment *)) bfd_false
252b5132
RH
2278
2279#endif
2280
2281#ifdef RS6000COFF_C
2282
7f6d05e8
CP
2283#ifdef XCOFF64
2284#define FORCE_SYMNAMES_IN_STRINGS
2285#endif
a022216b 2286
252b5132
RH
2287/* Handle the csect auxent of a C_EXT or C_HIDEXT symbol. */
2288
b34976b6 2289static bfd_boolean
7920ce38
NC
2290coff_pointerize_aux_hook (bfd *abfd ATTRIBUTE_UNUSED,
2291 combined_entry_type *table_base,
2292 combined_entry_type *symbol,
2293 unsigned int indaux,
2294 combined_entry_type *aux)
252b5132
RH
2295{
2296 int class = symbol->u.syment.n_sclass;
2297
2298 if ((class == C_EXT || class == C_HIDEXT)
2299 && indaux + 1 == symbol->u.syment.n_numaux)
2300 {
2301 if (SMTYP_SMTYP (aux->u.auxent.x_csect.x_smtyp) == XTY_LD)
2302 {
2303 aux->u.auxent.x_csect.x_scnlen.p =
2304 table_base + aux->u.auxent.x_csect.x_scnlen.l;
2305 aux->fix_scnlen = 1;
2306 }
2307
b34976b6 2308 /* Return TRUE to indicate that the caller should not do any
252b5132 2309 further work on this auxent. */
b34976b6 2310 return TRUE;
252b5132
RH
2311 }
2312
b34976b6 2313 /* Return FALSE to indicate that this auxent should be handled by
252b5132 2314 the caller. */
b34976b6 2315 return FALSE;
252b5132
RH
2316}
2317
2318#else
2319#ifdef I960
2320
2321/* We don't want to pointerize bal entries. */
2322
b34976b6 2323static bfd_boolean
7920ce38
NC
2324coff_pointerize_aux_hook (bfd *abfd ATTRIBUTE_UNUSED,
2325 combined_entry_type *table_base ATTRIBUTE_UNUSED,
2326 combined_entry_type *symbol,
2327 unsigned int indaux,
2328 combined_entry_type *aux ATTRIBUTE_UNUSED)
252b5132 2329{
b34976b6 2330 /* Return TRUE if we don't want to pointerize this aux entry, which
252b5132
RH
2331 is the case for the lastfirst aux entry for a C_LEAFPROC symbol. */
2332 return (indaux == 1
2333 && (symbol->u.syment.n_sclass == C_LEAFPROC
2334 || symbol->u.syment.n_sclass == C_LEAFSTAT
2335 || symbol->u.syment.n_sclass == C_LEAFEXT));
2336}
2337
2338#else /* ! I960 */
2339
2340#define coff_pointerize_aux_hook 0
2341
2342#endif /* ! I960 */
2343#endif /* ! RS6000COFF_C */
2344
b34976b6 2345/* Print an aux entry. This returns TRUE if it has printed it. */
252b5132 2346
b34976b6 2347static bfd_boolean
7920ce38
NC
2348coff_print_aux (bfd *abfd ATTRIBUTE_UNUSED,
2349 FILE *file ATTRIBUTE_UNUSED,
2350 combined_entry_type *table_base ATTRIBUTE_UNUSED,
2351 combined_entry_type *symbol ATTRIBUTE_UNUSED,
2352 combined_entry_type *aux ATTRIBUTE_UNUSED,
2353 unsigned int indaux ATTRIBUTE_UNUSED)
252b5132
RH
2354{
2355#ifdef RS6000COFF_C
2356 if ((symbol->u.syment.n_sclass == C_EXT
2357 || symbol->u.syment.n_sclass == C_HIDEXT)
2358 && indaux + 1 == symbol->u.syment.n_numaux)
2359 {
2360 /* This is a csect entry. */
2361 fprintf (file, "AUX ");
2362 if (SMTYP_SMTYP (aux->u.auxent.x_csect.x_smtyp) != XTY_LD)
2363 {
2364 BFD_ASSERT (! aux->fix_scnlen);
dc810e39 2365#ifdef XCOFF64
f60ca5e3
AM
2366 fprintf (file, "val %5lld",
2367 (long long) aux->u.auxent.x_csect.x_scnlen.l);
beb1bf64
TR
2368#else
2369 fprintf (file, "val %5ld", (long) aux->u.auxent.x_csect.x_scnlen.l);
2370#endif
252b5132
RH
2371 }
2372 else
2373 {
2374 fprintf (file, "indx ");
2375 if (! aux->fix_scnlen)
beb1bf64 2376#ifdef XCOFF64
f60ca5e3
AM
2377 fprintf (file, "%4lld",
2378 (long long) aux->u.auxent.x_csect.x_scnlen.l);
beb1bf64
TR
2379#else
2380 fprintf (file, "%4ld", (long) aux->u.auxent.x_csect.x_scnlen.l);
2381#endif
252b5132
RH
2382 else
2383 fprintf (file, "%4ld",
2384 (long) (aux->u.auxent.x_csect.x_scnlen.p - table_base));
2385 }
2386 fprintf (file,
2387 " prmhsh %ld snhsh %u typ %d algn %d clss %u stb %ld snstb %u",
2388 aux->u.auxent.x_csect.x_parmhash,
2389 (unsigned int) aux->u.auxent.x_csect.x_snhash,
2390 SMTYP_SMTYP (aux->u.auxent.x_csect.x_smtyp),
2391 SMTYP_ALIGN (aux->u.auxent.x_csect.x_smtyp),
2392 (unsigned int) aux->u.auxent.x_csect.x_smclas,
2393 aux->u.auxent.x_csect.x_stab,
2394 (unsigned int) aux->u.auxent.x_csect.x_snstab);
b34976b6 2395 return TRUE;
252b5132
RH
2396 }
2397#endif
2398
b34976b6
AM
2399 /* Return FALSE to indicate that no special action was taken. */
2400 return FALSE;
252b5132
RH
2401}
2402
2403/*
2404SUBSUBSECTION
2405 Writing relocations
2406
2407 To write relocations, the back end steps though the
2408 canonical relocation table and create an
2409 @code{internal_reloc}. The symbol index to use is removed from
2410 the @code{offset} field in the symbol table supplied. The
2411 address comes directly from the sum of the section base
2412 address and the relocation offset; the type is dug directly
2413 from the howto field. Then the @code{internal_reloc} is
2414 swapped into the shape of an @code{external_reloc} and written
2415 out to disk.
2416
2417*/
2418
2419#ifdef TARG_AUX
2420
252b5132 2421
ed781d5d 2422/* AUX's ld wants relocations to be sorted. */
252b5132 2423static int
7920ce38 2424compare_arelent_ptr (const void * x, const void * y)
252b5132
RH
2425{
2426 const arelent **a = (const arelent **) x;
2427 const arelent **b = (const arelent **) y;
2428 bfd_size_type aadr = (*a)->address;
2429 bfd_size_type badr = (*b)->address;
2430
2431 return (aadr < badr ? -1 : badr < aadr ? 1 : 0);
2432}
2433
2434#endif /* TARG_AUX */
2435
b34976b6 2436static bfd_boolean
7920ce38 2437coff_write_relocs (bfd * abfd, int first_undef)
252b5132
RH
2438{
2439 asection *s;
2440
7920ce38 2441 for (s = abfd->sections; s != NULL; s = s->next)
252b5132
RH
2442 {
2443 unsigned int i;
2444 struct external_reloc dst;
2445 arelent **p;
2446
2447#ifndef TARG_AUX
2448 p = s->orelocation;
2449#else
dc810e39 2450 {
ed781d5d 2451 /* Sort relocations before we write them out. */
dc810e39
AM
2452 bfd_size_type amt;
2453
2454 amt = s->reloc_count;
2455 amt *= sizeof (arelent *);
7920ce38 2456 p = bfd_malloc (amt);
dc810e39 2457 if (p == NULL && s->reloc_count > 0)
b34976b6 2458 return FALSE;
dc810e39
AM
2459 memcpy (p, s->orelocation, (size_t) amt);
2460 qsort (p, s->reloc_count, sizeof (arelent *), compare_arelent_ptr);
2461 }
252b5132
RH
2462#endif
2463
2464 if (bfd_seek (abfd, s->rel_filepos, SEEK_SET) != 0)
b34976b6 2465 return FALSE;
3e4554a2
DD
2466
2467#ifdef COFF_WITH_PE
e9168c1e 2468 if (obj_pe (abfd) && s->reloc_count >= 0xffff)
3e4554a2 2469 {
ed781d5d 2470 /* Encode real count here as first reloc. */
3e4554a2 2471 struct internal_reloc n;
ed781d5d 2472
7920ce38 2473 memset (& n, 0, sizeof (n));
ed781d5d 2474 /* Add one to count *this* reloc (grr). */
3e4554a2
DD
2475 n.r_vaddr = s->reloc_count + 1;
2476 coff_swap_reloc_out (abfd, &n, &dst);
7920ce38
NC
2477 if (bfd_bwrite (& dst, (bfd_size_type) bfd_coff_relsz (abfd),
2478 abfd) != bfd_coff_relsz (abfd))
b34976b6 2479 return FALSE;
3e4554a2
DD
2480 }
2481#endif
2482
252b5132
RH
2483 for (i = 0; i < s->reloc_count; i++)
2484 {
2485 struct internal_reloc n;
2486 arelent *q = p[i];
ed781d5d 2487
7920ce38 2488 memset (& n, 0, sizeof (n));
252b5132
RH
2489
2490 /* Now we've renumbered the symbols we know where the
2491 undefined symbols live in the table. Check the reloc
2492 entries for symbols who's output bfd isn't the right one.
2493 This is because the symbol was undefined (which means
2494 that all the pointers are never made to point to the same
2495 place). This is a bad thing,'cause the symbols attached
2496 to the output bfd are indexed, so that the relocation
2497 entries know which symbol index they point to. So we
e60b52c6 2498 have to look up the output symbol here. */
252b5132
RH
2499
2500 if (q->sym_ptr_ptr[0]->the_bfd != abfd)
2501 {
dc810e39 2502 int j;
252b5132
RH
2503 const char *sname = q->sym_ptr_ptr[0]->name;
2504 asymbol **outsyms = abfd->outsymbols;
ed781d5d 2505
dc810e39 2506 for (j = first_undef; outsyms[j]; j++)
252b5132 2507 {
dc810e39 2508 const char *intable = outsyms[j]->name;
ed781d5d 2509
7920ce38
NC
2510 if (strcmp (intable, sname) == 0)
2511 {
2512 /* Got a hit, so repoint the reloc. */
2513 q->sym_ptr_ptr = outsyms + j;
2514 break;
2515 }
252b5132
RH
2516 }
2517 }
2518
2519 n.r_vaddr = q->address + s->vma;
2520
2521#ifdef R_IHCONST
2522 /* The 29k const/consth reloc pair is a real kludge. The consth
2523 part doesn't have a symbol; it has an offset. So rebuilt
2524 that here. */
2525 if (q->howto->type == R_IHCONST)
2526 n.r_symndx = q->addend;
2527 else
2528#endif
2529 if (q->sym_ptr_ptr)
2530 {
6c784c9a 2531#ifdef SECTION_RELATIVE_ABSOLUTE_SYMBOL_P
7920ce38 2532 if (SECTION_RELATIVE_ABSOLUTE_SYMBOL_P (q, s))
6c784c9a 2533#else
250d94fd
AM
2534 if ((*q->sym_ptr_ptr)->section == bfd_abs_section_ptr
2535 && ((*q->sym_ptr_ptr)->flags & BSF_SECTION_SYM) != 0)
6c784c9a 2536#endif
252b5132
RH
2537 /* This is a relocation relative to the absolute symbol. */
2538 n.r_symndx = -1;
2539 else
2540 {
2541 n.r_symndx = get_index ((*(q->sym_ptr_ptr)));
337ff0a5
NC
2542 /* Check to see if the symbol reloc points to a symbol
2543 we don't have in our symbol table. */
252b5132 2544 if (n.r_symndx > obj_conv_table_size (abfd))
337ff0a5
NC
2545 {
2546 bfd_set_error (bfd_error_bad_value);
2547 _bfd_error_handler (_("%B: reloc against a non-existant symbol index: %ld"),
2548 abfd, n.r_symndx);
2549 return FALSE;
2550 }
252b5132
RH
2551 }
2552 }
2553
2554#ifdef SWAP_OUT_RELOC_OFFSET
2555 n.r_offset = q->addend;
2556#endif
2557
2558#ifdef SELECT_RELOC
ed781d5d 2559 /* Work out reloc type from what is required. */
252b5132
RH
2560 SELECT_RELOC (n, q->howto);
2561#else
2562 n.r_type = q->howto->type;
2563#endif
2564 coff_swap_reloc_out (abfd, &n, &dst);
ed781d5d 2565
7920ce38 2566 if (bfd_bwrite (& dst, (bfd_size_type) bfd_coff_relsz (abfd),
dc810e39 2567 abfd) != bfd_coff_relsz (abfd))
b34976b6 2568 return FALSE;
252b5132
RH
2569 }
2570
2571#ifdef TARG_AUX
2572 if (p != NULL)
2573 free (p);
2574#endif
2575 }
2576
b34976b6 2577 return TRUE;
252b5132
RH
2578}
2579
2580/* Set flags and magic number of a coff file from architecture and machine
b34976b6 2581 type. Result is TRUE if we can represent the arch&type, FALSE if not. */
252b5132 2582
b34976b6 2583static bfd_boolean
7920ce38
NC
2584coff_set_flags (bfd * abfd,
2585 unsigned int *magicp ATTRIBUTE_UNUSED,
2586 unsigned short *flagsp ATTRIBUTE_UNUSED)
252b5132
RH
2587{
2588 switch (bfd_get_arch (abfd))
2589 {
3c9b82ba
NC
2590#ifdef Z80MAGIC
2591 case bfd_arch_z80:
2592 *magicp = Z80MAGIC;
2593 switch (bfd_get_mach (abfd))
2594 {
2595 case 0:
2596 case bfd_mach_z80strict:
2597 case bfd_mach_z80:
2598 case bfd_mach_z80full:
2599 case bfd_mach_r800:
2600 *flagsp = bfd_get_mach (abfd) << 12;
2601 break;
2602 default:
2603 return FALSE;
2604 }
2605 return TRUE;
2606#endif
2607
252b5132
RH
2608#ifdef Z8KMAGIC
2609 case bfd_arch_z8k:
2610 *magicp = Z8KMAGIC;
7920ce38 2611
252b5132
RH
2612 switch (bfd_get_mach (abfd))
2613 {
7920ce38
NC
2614 case bfd_mach_z8001: *flagsp = F_Z8001; break;
2615 case bfd_mach_z8002: *flagsp = F_Z8002; break;
2616 default: return FALSE;
252b5132 2617 }
b34976b6 2618 return TRUE;
252b5132 2619#endif
252b5132 2620
7920ce38 2621#ifdef I960ROMAGIC
252b5132
RH
2622 case bfd_arch_i960:
2623
2624 {
2625 unsigned flags;
7920ce38 2626
252b5132 2627 *magicp = I960ROMAGIC;
7920ce38 2628
252b5132
RH
2629 switch (bfd_get_mach (abfd))
2630 {
7920ce38
NC
2631 case bfd_mach_i960_core: flags = F_I960CORE; break;
2632 case bfd_mach_i960_kb_sb: flags = F_I960KB; break;
2633 case bfd_mach_i960_mc: flags = F_I960MC; break;
2634 case bfd_mach_i960_xa: flags = F_I960XA; break;
2635 case bfd_mach_i960_ca: flags = F_I960CA; break;
2636 case bfd_mach_i960_ka_sa: flags = F_I960KA; break;
2637 case bfd_mach_i960_jx: flags = F_I960JX; break;
2638 case bfd_mach_i960_hx: flags = F_I960HX; break;
2639 default: return FALSE;
252b5132
RH
2640 }
2641 *flagsp = flags;
b34976b6 2642 return TRUE;
252b5132
RH
2643 }
2644 break;
2645#endif
2646
2647#ifdef TIC30MAGIC
2648 case bfd_arch_tic30:
2649 *magicp = TIC30MAGIC;
b34976b6 2650 return TRUE;
252b5132 2651#endif
81635ce4
TW
2652
2653#ifdef TICOFF_DEFAULT_MAGIC
2654 case TICOFF_TARGET_ARCH:
ed781d5d 2655 /* If there's no indication of which version we want, use the default. */
81635ce4
TW
2656 if (!abfd->xvec )
2657 *magicp = TICOFF_DEFAULT_MAGIC;
2658 else
2659 {
ed781d5d 2660 /* We may want to output in a different COFF version. */
81635ce4
TW
2661 switch (abfd->xvec->name[4])
2662 {
2663 case '0':
2664 *magicp = TICOFF0MAGIC;
2665 break;
2666 case '1':
2667 *magicp = TICOFF1MAGIC;
2668 break;
2669 case '2':
2670 *magicp = TICOFF2MAGIC;
2671 break;
2672 default:
b34976b6 2673 return FALSE;
81635ce4
TW
2674 }
2675 }
0da35f8b 2676 TICOFF_TARGET_MACHINE_SET (flagsp, bfd_get_mach (abfd));
b34976b6 2677 return TRUE;
81635ce4
TW
2678#endif
2679
252b5132
RH
2680#ifdef TIC80_ARCH_MAGIC
2681 case bfd_arch_tic80:
2682 *magicp = TIC80_ARCH_MAGIC;
b34976b6 2683 return TRUE;
252b5132 2684#endif
7920ce38 2685
252b5132
RH
2686#ifdef ARMMAGIC
2687 case bfd_arch_arm:
17505c5c
NC
2688#ifdef ARM_WINCE
2689 * magicp = ARMPEMAGIC;
2690#else
252b5132 2691 * magicp = ARMMAGIC;
17505c5c 2692#endif
252b5132
RH
2693 * flagsp = 0;
2694 if (APCS_SET (abfd))
2695 {
2696 if (APCS_26_FLAG (abfd))
2697 * flagsp |= F_APCS26;
e60b52c6 2698
252b5132
RH
2699 if (APCS_FLOAT_FLAG (abfd))
2700 * flagsp |= F_APCS_FLOAT;
e60b52c6 2701
252b5132 2702 if (PIC_FLAG (abfd))
948221a8 2703 * flagsp |= F_PIC;
252b5132
RH
2704 }
2705 if (INTERWORK_SET (abfd) && INTERWORK_FLAG (abfd))
2706 * flagsp |= F_INTERWORK;
2707 switch (bfd_get_mach (abfd))
2708 {
2709 case bfd_mach_arm_2: * flagsp |= F_ARM_2; break;
2710 case bfd_mach_arm_2a: * flagsp |= F_ARM_2a; break;
2711 case bfd_mach_arm_3: * flagsp |= F_ARM_3; break;
2712 case bfd_mach_arm_3M: * flagsp |= F_ARM_3M; break;
2713 case bfd_mach_arm_4: * flagsp |= F_ARM_4; break;
2714 case bfd_mach_arm_4T: * flagsp |= F_ARM_4T; break;
478d07d6 2715 case bfd_mach_arm_5: * flagsp |= F_ARM_5; break;
f13b834e
NC
2716 /* FIXME: we do not have F_ARM vaues greater than F_ARM_5.
2717 See also the comment in coff_set_arch_mach_hook(). */
077b8428
NC
2718 case bfd_mach_arm_5T: * flagsp |= F_ARM_5; break;
2719 case bfd_mach_arm_5TE: * flagsp |= F_ARM_5; break;
2720 case bfd_mach_arm_XScale: * flagsp |= F_ARM_5; break;
252b5132 2721 }
b34976b6 2722 return TRUE;
252b5132 2723#endif
7920ce38 2724
252b5132
RH
2725#ifdef PPCMAGIC
2726 case bfd_arch_powerpc:
2727 *magicp = PPCMAGIC;
b34976b6 2728 return TRUE;
252b5132 2729#endif
7920ce38 2730
99ad8390 2731#if defined(I386MAGIC) || defined(AMD64MAGIC)
252b5132 2732 case bfd_arch_i386:
99ad8390 2733#if defined(I386MAGIC)
252b5132 2734 *magicp = I386MAGIC;
99ad8390
NC
2735#endif
2736#if defined LYNXOS
e60b52c6 2737 /* Just overwrite the usual value if we're doing Lynx. */
252b5132 2738 *magicp = LYNXCOFFMAGIC;
99ad8390
NC
2739#endif
2740#if defined AMD64MAGIC
2741 *magicp = AMD64MAGIC;
252b5132 2742#endif
b34976b6 2743 return TRUE;
252b5132 2744#endif
7920ce38 2745
252b5132
RH
2746#ifdef I860MAGIC
2747 case bfd_arch_i860:
2748 *magicp = I860MAGIC;
b34976b6 2749 return TRUE;
252b5132 2750#endif
7920ce38 2751
fac41780
JW
2752#ifdef IA64MAGIC
2753 case bfd_arch_ia64:
2754 *magicp = IA64MAGIC;
b34976b6 2755 return TRUE;
fac41780 2756#endif
7920ce38 2757
252b5132
RH
2758#ifdef MC68MAGIC
2759 case bfd_arch_m68k:
2760#ifdef APOLLOM68KMAGIC
2761 *magicp = APOLLO_COFF_VERSION_NUMBER;
2762#else
2763 /* NAMES_HAVE_UNDERSCORE may be defined by coff-u68k.c. */
2764#ifdef NAMES_HAVE_UNDERSCORE
2765 *magicp = MC68KBCSMAGIC;
2766#else
2767 *magicp = MC68MAGIC;
2768#endif
2769#endif
2770#ifdef LYNXOS
e60b52c6 2771 /* Just overwrite the usual value if we're doing Lynx. */
252b5132
RH
2772 *magicp = LYNXCOFFMAGIC;
2773#endif
b34976b6 2774 return TRUE;
252b5132
RH
2775#endif
2776
2777#ifdef MC88MAGIC
2778 case bfd_arch_m88k:
2779 *magicp = MC88OMAGIC;
b34976b6 2780 return TRUE;
252b5132 2781#endif
7920ce38 2782
252b5132
RH
2783#ifdef H8300MAGIC
2784 case bfd_arch_h8300:
2785 switch (bfd_get_mach (abfd))
2786 {
7920ce38
NC
2787 case bfd_mach_h8300: *magicp = H8300MAGIC; return TRUE;
2788 case bfd_mach_h8300h: *magicp = H8300HMAGIC; return TRUE;
2789 case bfd_mach_h8300s: *magicp = H8300SMAGIC; return TRUE;
2790 case bfd_mach_h8300hn: *magicp = H8300HNMAGIC; return TRUE;
2791 case bfd_mach_h8300sn: *magicp = H8300SNMAGIC; return TRUE;
2792 default: break;
252b5132
RH
2793 }
2794 break;
2795#endif
2796
2797#ifdef SH_ARCH_MAGIC_BIG
2798 case bfd_arch_sh:
17505c5c
NC
2799#ifdef COFF_IMAGE_WITH_PE
2800 *magicp = SH_ARCH_MAGIC_WINCE;
2801#else
252b5132
RH
2802 if (bfd_big_endian (abfd))
2803 *magicp = SH_ARCH_MAGIC_BIG;
2804 else
2805 *magicp = SH_ARCH_MAGIC_LITTLE;
17505c5c 2806#endif
b34976b6 2807 return TRUE;
17505c5c
NC
2808#endif
2809
2810#ifdef MIPS_ARCH_MAGIC_WINCE
2811 case bfd_arch_mips:
2812 *magicp = MIPS_ARCH_MAGIC_WINCE;
b34976b6 2813 return TRUE;
252b5132
RH
2814#endif
2815
2816#ifdef SPARCMAGIC
2817 case bfd_arch_sparc:
2818 *magicp = SPARCMAGIC;
2819#ifdef LYNXOS
e60b52c6 2820 /* Just overwrite the usual value if we're doing Lynx. */
252b5132
RH
2821 *magicp = LYNXCOFFMAGIC;
2822#endif
b34976b6 2823 return TRUE;
252b5132
RH
2824#endif
2825
2826#ifdef H8500MAGIC
2827 case bfd_arch_h8500:
2828 *magicp = H8500MAGIC;
b34976b6 2829 return TRUE;
252b5132
RH
2830 break;
2831#endif
7920ce38 2832
252b5132
RH
2833#ifdef WE32KMAGIC
2834 case bfd_arch_we32k:
2835 *magicp = WE32KMAGIC;
b34976b6 2836 return TRUE;
252b5132
RH
2837#endif
2838
7f6d05e8 2839#ifdef RS6000COFF_C
252b5132
RH
2840 case bfd_arch_rs6000:
2841#ifndef PPCMAGIC
2842 case bfd_arch_powerpc:
2843#endif
eb1e0e80
NC
2844 BFD_ASSERT (bfd_get_flavour (abfd) == bfd_target_xcoff_flavour);
2845 *magicp = bfd_xcoff_magic_number (abfd);
b34976b6 2846 return TRUE;
252b5132
RH
2847#endif
2848
2849#ifdef MCOREMAGIC
2850 case bfd_arch_mcore:
2851 * magicp = MCOREMAGIC;
b34976b6 2852 return TRUE;
252b5132 2853#endif
e60b52c6 2854
371e71b8
NC
2855#ifdef W65MAGIC
2856 case bfd_arch_w65:
2857 *magicp = W65MAGIC;
b34976b6 2858 return TRUE;
371e71b8
NC
2859#endif
2860
3b16e843
NC
2861#ifdef OR32_MAGIC_BIG
2862 case bfd_arch_or32:
2863 if (bfd_big_endian (abfd))
2864 * magicp = OR32_MAGIC_BIG;
2865 else
2866 * magicp = OR32_MAGIC_LITTLE;
b34976b6 2867 return TRUE;
3b16e843
NC
2868#endif
2869
7499d566
NC
2870#ifdef MAXQ20MAGIC
2871 case bfd_arch_maxq:
5c4504f7
NC
2872 * magicp = MAXQ20MAGIC;
2873 switch (bfd_get_mach (abfd))
2874 {
7920ce38
NC
2875 case bfd_mach_maxq10: * flagsp = F_MAXQ10; return TRUE;
2876 case bfd_mach_maxq20: * flagsp = F_MAXQ20; return TRUE;
2877 default: return FALSE;
5c4504f7 2878 }
7499d566
NC
2879#endif
2880
371e71b8 2881 default: /* Unknown architecture. */
b34976b6 2882 /* Fall through to "return FALSE" below, to avoid
371e71b8 2883 "statement never reached" errors on the one below. */
252b5132
RH
2884 break;
2885 }
2886
b34976b6 2887 return FALSE;
252b5132
RH
2888}
2889
b34976b6 2890static bfd_boolean
7920ce38
NC
2891coff_set_arch_mach (bfd * abfd,
2892 enum bfd_architecture arch,
2893 unsigned long machine)
252b5132
RH
2894{
2895 unsigned dummy1;
2896 unsigned short dummy2;
2897
2898 if (! bfd_default_set_arch_mach (abfd, arch, machine))
b34976b6 2899 return FALSE;
252b5132 2900
82e51918
AM
2901 if (arch != bfd_arch_unknown
2902 && ! coff_set_flags (abfd, &dummy1, &dummy2))
7920ce38 2903 return FALSE; /* We can't represent this type. */
252b5132 2904
7920ce38 2905 return TRUE; /* We're easy... */
252b5132
RH
2906}
2907
75cc7189
ILT
2908#ifdef COFF_IMAGE_WITH_PE
2909
2910/* This is used to sort sections by VMA, as required by PE image
2911 files. */
2912
75cc7189 2913static int
7920ce38 2914sort_by_secaddr (const void * arg1, const void * arg2)
75cc7189
ILT
2915{
2916 const asection *a = *(const asection **) arg1;
2917 const asection *b = *(const asection **) arg2;
2918
2919 if (a->vma < b->vma)
2920 return -1;
2921 else if (a->vma > b->vma)
2922 return 1;
7920ce38
NC
2923
2924 return 0;
75cc7189
ILT
2925}
2926
2927#endif /* COFF_IMAGE_WITH_PE */
252b5132 2928
e60b52c6 2929/* Calculate the file position for each section. */
252b5132
RH
2930
2931#ifndef I960
2932#define ALIGN_SECTIONS_IN_FILE
2933#endif
81635ce4 2934#if defined(TIC80COFF) || defined(TICOFF)
252b5132
RH
2935#undef ALIGN_SECTIONS_IN_FILE
2936#endif
2937
b34976b6 2938static bfd_boolean
7920ce38 2939coff_compute_section_file_positions (bfd * abfd)
252b5132
RH
2940{
2941 asection *current;
7920ce38 2942 asection *previous = NULL;
6b3b007b 2943 file_ptr sofar = bfd_coff_filhsz (abfd);
b34976b6 2944 bfd_boolean align_adjust;
252b5132
RH
2945#ifdef ALIGN_SECTIONS_IN_FILE
2946 file_ptr old_sofar;
2947#endif
2948
2949#ifdef RS6000COFF_C
2950 /* On XCOFF, if we have symbols, set up the .debug section. */
2951 if (bfd_get_symcount (abfd) > 0)
2952 {
2953 bfd_size_type sz;
2954 bfd_size_type i, symcount;
2955 asymbol **symp;
2956
2957 sz = 0;
2958 symcount = bfd_get_symcount (abfd);
2959 for (symp = abfd->outsymbols, i = 0; i < symcount; symp++, i++)
2960 {
2961 coff_symbol_type *cf;
2962
2963 cf = coff_symbol_from (abfd, *symp);
2964 if (cf != NULL
2965 && cf->native != NULL
2966 && SYMNAME_IN_DEBUG (&cf->native->u.syment))
2967 {
2968 size_t len;
2969
2970 len = strlen (bfd_asymbol_name (*symp));
7f6d05e8
CP
2971 if (len > SYMNMLEN || bfd_coff_force_symnames_in_strings (abfd))
2972 sz += len + 1 + bfd_coff_debug_string_prefix_length (abfd);
252b5132
RH
2973 }
2974 }
2975 if (sz > 0)
2976 {
2977 asection *dsec;
2978
8a7140c3 2979 dsec = bfd_make_section_old_way (abfd, DOT_DEBUG);
252b5132
RH
2980 if (dsec == NULL)
2981 abort ();
eea6121a 2982 dsec->size = sz;
252b5132
RH
2983 dsec->flags |= SEC_HAS_CONTENTS;
2984 }
2985 }
2986#endif
2987
2988#ifdef COFF_IMAGE_WITH_PE
2989 int page_size;
7920ce38 2990
e60b52c6 2991 if (coff_data (abfd)->link_info)
252b5132
RH
2992 {
2993 page_size = pe_data (abfd)->pe_opthdr.FileAlignment;
771e446b
NC
2994
2995 /* If no file alignment has been set, default to one.
2996 This repairs 'ld -r' for arm-wince-pe target. */
2997 if (page_size == 0)
2998 page_size = 1;
252b5132
RH
2999 }
3000 else
3001 page_size = PE_DEF_FILE_ALIGNMENT;
3002#else
3003#ifdef COFF_PAGE_SIZE
3004 int page_size = COFF_PAGE_SIZE;
3005#endif
3006#endif
3007
3008 if (bfd_get_start_address (abfd))
7920ce38
NC
3009 /* A start address may have been added to the original file. In this
3010 case it will need an optional header to record it. */
3011 abfd->flags |= EXEC_P;
252b5132
RH
3012
3013 if (abfd->flags & EXEC_P)
6b3b007b 3014 sofar += bfd_coff_aoutsz (abfd);
252b5132
RH
3015#ifdef RS6000COFF_C
3016 else if (xcoff_data (abfd)->full_aouthdr)
6b3b007b 3017 sofar += bfd_coff_aoutsz (abfd);
252b5132
RH
3018 else
3019 sofar += SMALL_AOUTSZ;
3020#endif
3021
6b3b007b 3022 sofar += abfd->section_count * bfd_coff_scnhsz (abfd);
252b5132
RH
3023
3024#ifdef RS6000COFF_C
3025 /* XCOFF handles overflows in the reloc and line number count fields
3026 by allocating a new section header to hold the correct counts. */
3027 for (current = abfd->sections; current != NULL; current = current->next)
3028 if (current->reloc_count >= 0xffff || current->lineno_count >= 0xffff)
6b3b007b 3029 sofar += bfd_coff_scnhsz (abfd);
252b5132
RH
3030#endif
3031
75cc7189
ILT
3032#ifdef COFF_IMAGE_WITH_PE
3033 {
3034 /* PE requires the sections to be in memory order when listed in
3035 the section headers. It also does not like empty loadable
3036 sections. The sections apparently do not have to be in the
3037 right order in the image file itself, but we do need to get the
3038 target_index values right. */
3039
dc810e39 3040 unsigned int count;
75cc7189 3041 asection **section_list;
dc810e39 3042 unsigned int i;
75cc7189 3043 int target_index;
dc810e39 3044 bfd_size_type amt;
75cc7189
ILT
3045
3046 count = 0;
3047 for (current = abfd->sections; current != NULL; current = current->next)
3048 ++count;
3049
3050 /* We allocate an extra cell to simplify the final loop. */
dc810e39
AM
3051 amt = sizeof (struct asection *) * (count + 1);
3052 section_list = bfd_malloc (amt);
75cc7189 3053 if (section_list == NULL)
b34976b6 3054 return FALSE;
75cc7189
ILT
3055
3056 i = 0;
3057 for (current = abfd->sections; current != NULL; current = current->next)
3058 {
3059 section_list[i] = current;
3060 ++i;
3061 }
3062 section_list[i] = NULL;
3063
3064 qsort (section_list, count, sizeof (asection *), sort_by_secaddr);
3065
3066 /* Rethread the linked list into sorted order; at the same time,
3067 assign target_index values. */
3068 target_index = 1;
5daa8fe7
L
3069 abfd->sections = NULL;
3070 abfd->section_last = NULL;
75cc7189
ILT
3071 for (i = 0; i < count; i++)
3072 {
3073 current = section_list[i];
5daa8fe7 3074 bfd_section_list_append (abfd, current);
75cc7189
ILT
3075
3076 /* Later, if the section has zero size, we'll be throwing it
3077 away, so we don't want to number it now. Note that having
3078 a zero size and having real contents are different
3079 concepts: .bss has no contents, but (usually) non-zero
3080 size. */
eea6121a 3081 if (current->size == 0)
75cc7189
ILT
3082 {
3083 /* Discard. However, it still might have (valid) symbols
3084 in it, so arbitrarily set it to section 1 (indexing is
3085 1-based here; usually .text). __end__ and other
3086 contents of .endsection really have this happen.
3087 FIXME: This seems somewhat dubious. */
3088 current->target_index = 1;
3089 }
3090 else
3091 current->target_index = target_index++;
3092 }
3093
2fca4467 3094 free (section_list);
75cc7189
ILT
3095 }
3096#else /* ! COFF_IMAGE_WITH_PE */
3097 {
3098 /* Set the target_index field. */
3099 int target_index;
3100
3101 target_index = 1;
3102 for (current = abfd->sections; current != NULL; current = current->next)
3103 current->target_index = target_index++;
3104 }
3105#endif /* ! COFF_IMAGE_WITH_PE */
3106
b34976b6 3107 align_adjust = FALSE;
75cc7189 3108 for (current = abfd->sections;
7920ce38 3109 current != NULL;
75cc7189 3110 current = current->next)
252b5132
RH
3111 {
3112#ifdef COFF_IMAGE_WITH_PE
75cc7189
ILT
3113 /* With PE we have to pad each section to be a multiple of its
3114 page size too, and remember both sizes. */
3115 if (coff_section_data (abfd, current) == NULL)
252b5132 3116 {
dc810e39 3117 bfd_size_type amt = sizeof (struct coff_section_tdata);
7920ce38
NC
3118
3119 current->used_by_bfd = bfd_zalloc (abfd, amt);
75cc7189 3120 if (current->used_by_bfd == NULL)
b34976b6 3121 return FALSE;
252b5132 3122 }
75cc7189
ILT
3123 if (pei_section_data (abfd, current) == NULL)
3124 {
dc810e39 3125 bfd_size_type amt = sizeof (struct pei_section_tdata);
7920ce38
NC
3126
3127 coff_section_data (abfd, current)->tdata = bfd_zalloc (abfd, amt);
75cc7189 3128 if (coff_section_data (abfd, current)->tdata == NULL)
b34976b6 3129 return FALSE;
75cc7189
ILT
3130 }
3131 if (pei_section_data (abfd, current)->virt_size == 0)
eea6121a 3132 pei_section_data (abfd, current)->virt_size = current->size;
252b5132
RH
3133#endif
3134
75cc7189 3135 /* Only deal with sections which have contents. */
252b5132
RH
3136 if (!(current->flags & SEC_HAS_CONTENTS))
3137 continue;
3138
75cc7189
ILT
3139#ifdef COFF_IMAGE_WITH_PE
3140 /* Make sure we skip empty sections in a PE image. */
eea6121a 3141 if (current->size == 0)
75cc7189
ILT
3142 continue;
3143#endif
3144
252b5132
RH
3145 /* Align the sections in the file to the same boundary on
3146 which they are aligned in virtual memory. I960 doesn't
3147 do this (FIXME) so we can stay in sync with Intel. 960
e60b52c6 3148 doesn't yet page from files... */
252b5132
RH
3149#ifdef ALIGN_SECTIONS_IN_FILE
3150 if ((abfd->flags & EXEC_P) != 0)
3151 {
ed781d5d
NC
3152 /* Make sure this section is aligned on the right boundary - by
3153 padding the previous section up if necessary. */
252b5132 3154 old_sofar = sofar;
7920ce38 3155
47ede03a
TR
3156#ifdef RS6000COFF_C
3157 /* AIX loader checks the text section alignment of (vma - filepos)
3158 So even though the filepos may be aligned wrt the o_algntext, for
19852a2a 3159 AIX executables, this check fails. This shows up when a native
47ede03a
TR
3160 AIX executable is stripped with gnu strip because the default vma
3161 of native is 0x10000150 but default for gnu is 0x10000140. Gnu
b34976b6 3162 stripped gnu excutable passes this check because the filepos is
f3813499
TR
3163 0x0140. This problem also show up with 64 bit shared objects. The
3164 data section must also be aligned. */
b34976b6
AM
3165 if (!strcmp (current->name, _TEXT)
3166 || !strcmp (current->name, _DATA))
47ede03a
TR
3167 {
3168 bfd_vma pad;
3169 bfd_vma align;
3170
3171 sofar = BFD_ALIGN (sofar, 1 << current->alignment_power);
3172
3173 align = 1 << current->alignment_power;
3174 pad = abs (current->vma - sofar) % align;
b34976b6
AM
3175
3176 if (pad)
47ede03a
TR
3177 {
3178 pad = align - pad;
3179 sofar += pad;
3180 }
3181 }
3182 else
3183#else
3184 {
3185 sofar = BFD_ALIGN (sofar, 1 << current->alignment_power);
3186 }
3187#endif
7920ce38 3188 if (previous != NULL)
eea6121a 3189 previous->size += sofar - old_sofar;
252b5132
RH
3190 }
3191
3192#endif
3193
3194 /* In demand paged files the low order bits of the file offset
3195 must match the low order bits of the virtual address. */
3196#ifdef COFF_PAGE_SIZE
3197 if ((abfd->flags & D_PAGED) != 0
3198 && (current->flags & SEC_ALLOC) != 0)
7bf6dede 3199 sofar += (current->vma - (bfd_vma) sofar) % page_size;
252b5132
RH
3200#endif
3201 current->filepos = sofar;
3202
3203#ifdef COFF_IMAGE_WITH_PE
75cc7189 3204 /* Set the padded size. */
eea6121a 3205 current->size = (current->size + page_size -1) & -page_size;
252b5132
RH
3206#endif
3207
eea6121a 3208 sofar += current->size;
252b5132
RH
3209
3210#ifdef ALIGN_SECTIONS_IN_FILE
ed781d5d 3211 /* Make sure that this section is of the right size too. */
252b5132
RH
3212 if ((abfd->flags & EXEC_P) == 0)
3213 {
3214 bfd_size_type old_size;
3215
eea6121a
AM
3216 old_size = current->size;
3217 current->size = BFD_ALIGN (current->size,
3218 1 << current->alignment_power);
3219 align_adjust = current->size != old_size;
3220 sofar += current->size - old_size;
252b5132
RH
3221 }
3222 else
3223 {
3224 old_sofar = sofar;
3225 sofar = BFD_ALIGN (sofar, 1 << current->alignment_power);
3226 align_adjust = sofar != old_sofar;
eea6121a 3227 current->size += sofar - old_sofar;
252b5132
RH
3228 }
3229#endif
3230
3231#ifdef COFF_IMAGE_WITH_PE
3232 /* For PE we need to make sure we pad out to the aligned
eea6121a
AM
3233 size, in case the caller only writes out data to the
3234 unaligned size. */
3235 if (pei_section_data (abfd, current)->virt_size < current->size)
b34976b6 3236 align_adjust = TRUE;
252b5132
RH
3237#endif
3238
3239#ifdef _LIB
3240 /* Force .lib sections to start at zero. The vma is then
3241 incremented in coff_set_section_contents. This is right for
3242 SVR3.2. */
3243 if (strcmp (current->name, _LIB) == 0)
3244 bfd_set_section_vma (abfd, current, 0);
3245#endif
3246
3247 previous = current;
3248 }
3249
3250 /* It is now safe to write to the output file. If we needed an
3251 alignment adjustment for the last section, then make sure that
3252 there is a byte at offset sofar. If there are no symbols and no
3253 relocs, then nothing follows the last section. If we don't force
3254 the last byte out, then the file may appear to be truncated. */
3255 if (align_adjust)
3256 {
3257 bfd_byte b;
3258
3259 b = 0;
3260 if (bfd_seek (abfd, sofar - 1, SEEK_SET) != 0
dc810e39 3261 || bfd_bwrite (&b, (bfd_size_type) 1, abfd) != 1)
b34976b6 3262 return FALSE;
252b5132
RH
3263 }
3264
3265 /* Make sure the relocations are aligned. We don't need to make
3266 sure that this byte exists, because it will only matter if there
3267 really are relocs. */
3268 sofar = BFD_ALIGN (sofar, 1 << COFF_DEFAULT_SECTION_ALIGNMENT_POWER);
3269
3270 obj_relocbase (abfd) = sofar;
b34976b6 3271 abfd->output_has_begun = TRUE;
252b5132 3272
b34976b6 3273 return TRUE;
252b5132
RH
3274}
3275
05793179
NC
3276#ifdef COFF_IMAGE_WITH_PE
3277
3278static unsigned int pelength;
3279static unsigned int peheader;
3280
b34976b6 3281static bfd_boolean
7920ce38 3282coff_read_word (bfd *abfd, unsigned int *value)
05793179
NC
3283{
3284 unsigned char b[2];
3285 int status;
3286
3287 status = bfd_bread (b, (bfd_size_type) 2, abfd);
3288 if (status < 1)
3289 {
3290 *value = 0;
b34976b6 3291 return FALSE;
05793179
NC
3292 }
3293
3294 if (status == 1)
3295 *value = (unsigned int) b[0];
3296 else
3297 *value = (unsigned int) (b[0] + (b[1] << 8));
3298
3299 pelength += (unsigned int) status;
3300
b34976b6 3301 return TRUE;
05793179
NC
3302}
3303
3304static unsigned int
7920ce38 3305coff_compute_checksum (bfd *abfd)
05793179 3306{
b34976b6 3307 bfd_boolean more_data;
05793179
NC
3308 file_ptr filepos;
3309 unsigned int value;
3310 unsigned int total;
3311
3312 total = 0;
3313 pelength = 0;
3314 filepos = (file_ptr) 0;
3315
3316 do
3317 {
3318 if (bfd_seek (abfd, filepos, SEEK_SET) != 0)
3319 return 0;
3320
3321 more_data = coff_read_word (abfd, &value);
3322 total += value;
3323 total = 0xffff & (total + (total >> 0x10));
3324 filepos += 2;
3325 }
3326 while (more_data);
3327
3328 return (0xffff & (total + (total >> 0x10)));
3329}
3330
b34976b6 3331static bfd_boolean
7920ce38 3332coff_apply_checksum (bfd *abfd)
05793179
NC
3333{
3334 unsigned int computed;
3335 unsigned int checksum = 0;
3336
3337 if (bfd_seek (abfd, 0x3c, SEEK_SET) != 0)
b34976b6 3338 return FALSE;
05793179
NC
3339
3340 if (!coff_read_word (abfd, &peheader))
b34976b6 3341 return FALSE;
05793179
NC
3342
3343 if (bfd_seek (abfd, peheader + 0x58, SEEK_SET) != 0)
b34976b6 3344 return FALSE;
05793179
NC
3345
3346 checksum = 0;
3347 bfd_bwrite (&checksum, (bfd_size_type) 4, abfd);
3348
3349 if (bfd_seek (abfd, peheader, SEEK_SET) != 0)
b34976b6 3350 return FALSE;
05793179
NC
3351
3352 computed = coff_compute_checksum (abfd);
3353
3354 checksum = computed + pelength;
3355
3356 if (bfd_seek (abfd, peheader + 0x58, SEEK_SET) != 0)
b34976b6 3357 return FALSE;
05793179
NC
3358
3359 bfd_bwrite (&checksum, (bfd_size_type) 4, abfd);
3360
b34976b6 3361 return TRUE;
05793179
NC
3362}
3363
3364#endif /* COFF_IMAGE_WITH_PE */
3365
b34976b6 3366static bfd_boolean
7920ce38 3367coff_write_object_contents (bfd * abfd)
252b5132
RH
3368{
3369 asection *current;
b34976b6
AM
3370 bfd_boolean hasrelocs = FALSE;
3371 bfd_boolean haslinno = FALSE;
3372 bfd_boolean hasdebug = FALSE;
252b5132
RH
3373 file_ptr scn_base;
3374 file_ptr reloc_base;
3375 file_ptr lineno_base;
3376 file_ptr sym_base;
3e4554a2 3377 unsigned long reloc_size = 0, reloc_count = 0;
252b5132 3378 unsigned long lnno_size = 0;
b34976b6 3379 bfd_boolean long_section_names;
252b5132
RH
3380 asection *text_sec = NULL;
3381 asection *data_sec = NULL;
3382 asection *bss_sec = NULL;
3383 struct internal_filehdr internal_f;
3384 struct internal_aouthdr internal_a;
3385#ifdef COFF_LONG_SECTION_NAMES
3386 size_t string_size = STRING_SIZE_SIZE;
3387#endif
3388
3389 bfd_set_error (bfd_error_system_call);
3390
3391 /* Make a pass through the symbol table to count line number entries and
ed781d5d 3392 put them into the correct asections. */
6b3b007b 3393 lnno_size = coff_count_linenumbers (abfd) * bfd_coff_linesz (abfd);
252b5132 3394
82e51918 3395 if (! abfd->output_has_begun)
252b5132
RH
3396 {
3397 if (! coff_compute_section_file_positions (abfd))
b34976b6 3398 return FALSE;
252b5132
RH
3399 }
3400
3401 reloc_base = obj_relocbase (abfd);
3402
ed781d5d 3403 /* Work out the size of the reloc and linno areas. */
252b5132
RH
3404
3405 for (current = abfd->sections; current != NULL; current =
3406 current->next)
3e4554a2
DD
3407 {
3408#ifdef COFF_WITH_PE
ed781d5d 3409 /* We store the actual reloc count in the first reloc's addr. */
e9168c1e 3410 if (obj_pe (abfd) && current->reloc_count >= 0xffff)
3e4554a2
DD
3411 reloc_count ++;
3412#endif
3413 reloc_count += current->reloc_count;
3414 }
3415
3416 reloc_size = reloc_count * bfd_coff_relsz (abfd);
252b5132
RH
3417
3418 lineno_base = reloc_base + reloc_size;
3419 sym_base = lineno_base + lnno_size;
3420
ed781d5d 3421 /* Indicate in each section->line_filepos its actual file address. */
252b5132
RH
3422 for (current = abfd->sections; current != NULL; current =
3423 current->next)
3424 {
3425 if (current->lineno_count)
3426 {
3427 current->line_filepos = lineno_base;
3428 current->moving_line_filepos = lineno_base;
6b3b007b 3429 lineno_base += current->lineno_count * bfd_coff_linesz (abfd);
252b5132
RH
3430 }
3431 else
7920ce38
NC
3432 current->line_filepos = 0;
3433
252b5132
RH
3434 if (current->reloc_count)
3435 {
3436 current->rel_filepos = reloc_base;
6b3b007b 3437 reloc_base += current->reloc_count * bfd_coff_relsz (abfd);
3e4554a2 3438#ifdef COFF_WITH_PE
ed781d5d 3439 /* Extra reloc to hold real count. */
e9168c1e 3440 if (obj_pe (abfd) && current->reloc_count >= 0xffff)
3e4554a2
DD
3441 reloc_base += bfd_coff_relsz (abfd);
3442#endif
252b5132
RH
3443 }
3444 else
7920ce38 3445 current->rel_filepos = 0;
252b5132
RH
3446 }
3447
3448 /* Write section headers to the file. */
3449 internal_f.f_nscns = 0;
3450
3451 if ((abfd->flags & EXEC_P) != 0)
6b3b007b 3452 scn_base = bfd_coff_filhsz (abfd) + bfd_coff_aoutsz (abfd);
252b5132
RH
3453 else
3454 {
6b3b007b 3455 scn_base = bfd_coff_filhsz (abfd);
252b5132 3456#ifdef RS6000COFF_C
dc810e39 3457#ifndef XCOFF64
252b5132 3458 if (xcoff_data (abfd)->full_aouthdr)
6b3b007b 3459 scn_base += bfd_coff_aoutsz (abfd);
252b5132
RH
3460 else
3461 scn_base += SMALL_AOUTSZ;
dc810e39 3462#endif
252b5132
RH
3463#endif
3464 }
3465
3466 if (bfd_seek (abfd, scn_base, SEEK_SET) != 0)
b34976b6 3467 return FALSE;
252b5132 3468
b34976b6 3469 long_section_names = FALSE;
252b5132
RH
3470 for (current = abfd->sections;
3471 current != NULL;
3472 current = current->next)
3473 {
3474 struct internal_scnhdr section;
b34976b6 3475 bfd_boolean is_reloc_section = FALSE;
252b5132
RH
3476
3477#ifdef COFF_IMAGE_WITH_PE
3478 if (strcmp (current->name, ".reloc") == 0)
3479 {
b34976b6
AM
3480 is_reloc_section = TRUE;
3481 hasrelocs = TRUE;
252b5132
RH
3482 pe_data (abfd)->has_reloc_section = 1;
3483 }
3484#endif
3485
252b5132
RH
3486 internal_f.f_nscns++;
3487
3488 strncpy (section.s_name, current->name, SCNNMLEN);
3489
3490#ifdef COFF_LONG_SECTION_NAMES
3491 /* Handle long section names as in PE. This must be compatible
00692651 3492 with the code in coff_write_symbols and _bfd_coff_final_link. */
252b5132
RH
3493 {
3494 size_t len;
3495
3496 len = strlen (current->name);
3497 if (len > SCNNMLEN)
3498 {
3499 memset (section.s_name, 0, SCNNMLEN);
3500 sprintf (section.s_name, "/%lu", (unsigned long) string_size);
3501 string_size += len + 1;
b34976b6 3502 long_section_names = TRUE;
252b5132
RH
3503 }
3504 }
3505#endif
3506
3507#ifdef _LIB
3508 /* Always set s_vaddr of .lib to 0. This is right for SVR3.2
3509 Ian Taylor <ian@cygnus.com>. */
3510 if (strcmp (current->name, _LIB) == 0)
3511 section.s_vaddr = 0;
3512 else
3513#endif
3514 section.s_vaddr = current->vma;
3515 section.s_paddr = current->lma;
eea6121a 3516 section.s_size = current->size;
b9af77f5 3517#ifdef coff_get_section_load_page
e60b52c6 3518 section.s_page = coff_get_section_load_page (current);
b9af77f5 3519#endif
252b5132
RH
3520
3521#ifdef COFF_WITH_PE
3522 section.s_paddr = 0;
3523#endif
3524#ifdef COFF_IMAGE_WITH_PE
3525 /* Reminder: s_paddr holds the virtual size of the section. */
3526 if (coff_section_data (abfd, current) != NULL
3527 && pei_section_data (abfd, current) != NULL)
3528 section.s_paddr = pei_section_data (abfd, current)->virt_size;
3529 else
3530 section.s_paddr = 0;
3531#endif
3532
ed781d5d
NC
3533 /* If this section has no size or is unloadable then the scnptr
3534 will be 0 too. */
eea6121a
AM
3535 if (current->size == 0
3536 || (current->flags & (SEC_LOAD | SEC_HAS_CONTENTS)) == 0)
ed781d5d 3537 section.s_scnptr = 0;
252b5132 3538 else
ed781d5d
NC
3539 section.s_scnptr = current->filepos;
3540
252b5132
RH
3541 section.s_relptr = current->rel_filepos;
3542 section.s_lnnoptr = current->line_filepos;
3543 section.s_nreloc = current->reloc_count;
3544 section.s_nlnno = current->lineno_count;
79207490
ILT
3545#ifndef COFF_IMAGE_WITH_PE
3546 /* In PEI, relocs come in the .reloc section. */
252b5132 3547 if (current->reloc_count != 0)
b34976b6 3548 hasrelocs = TRUE;
79207490 3549#endif
252b5132 3550 if (current->lineno_count != 0)
b34976b6 3551 haslinno = TRUE;
4cfec37b
ILT
3552 if ((current->flags & SEC_DEBUGGING) != 0
3553 && ! is_reloc_section)
b34976b6 3554 hasdebug = TRUE;
252b5132 3555
60bcf0fa 3556#ifdef RS6000COFF_C
7f6d05e8 3557#ifndef XCOFF64
252b5132
RH
3558 /* Indicate the use of an XCOFF overflow section header. */
3559 if (current->reloc_count >= 0xffff || current->lineno_count >= 0xffff)
3560 {
3561 section.s_nreloc = 0xffff;
3562 section.s_nlnno = 0xffff;
3563 }
7f6d05e8 3564#endif
252b5132
RH
3565#endif
3566
3567 section.s_flags = sec_to_styp_flags (current->name, current->flags);
3568
3569 if (!strcmp (current->name, _TEXT))
ed781d5d 3570 text_sec = current;
252b5132 3571 else if (!strcmp (current->name, _DATA))
ed781d5d 3572 data_sec = current;
252b5132 3573 else if (!strcmp (current->name, _BSS))
ed781d5d 3574 bss_sec = current;
252b5132
RH
3575
3576#ifdef I960
3577 section.s_align = (current->alignment_power
3578 ? 1 << current->alignment_power
3579 : 0);
81635ce4 3580#endif
e60b52c6 3581#ifdef TIC80COFF
ed781d5d 3582 /* TI COFF puts the alignment power in bits 8-11 of the flags. */
252b5132
RH
3583 section.s_flags |= (current->alignment_power & 0xF) << 8;
3584#endif
81635ce4
TW
3585#ifdef COFF_ENCODE_ALIGNMENT
3586 COFF_ENCODE_ALIGNMENT(section, current->alignment_power);
252b5132
RH
3587#endif
3588
3589#ifdef COFF_IMAGE_WITH_PE
00692651
ILT
3590 /* Suppress output of the sections if they are null. ld
3591 includes the bss and data sections even if there is no size
3592 assigned to them. NT loader doesn't like it if these section
3593 headers are included if the sections themselves are not
3594 needed. See also coff_compute_section_file_positions. */
252b5132
RH
3595 if (section.s_size == 0)
3596 internal_f.f_nscns--;
3597 else
3598#endif
3599 {
3600 SCNHDR buff;
dc810e39
AM
3601 bfd_size_type amt = bfd_coff_scnhsz (abfd);
3602
252b5132 3603 if (coff_swap_scnhdr_out (abfd, &section, &buff) == 0
7920ce38 3604 || bfd_bwrite (& buff, amt, abfd) != amt)
b34976b6 3605 return FALSE;
252b5132
RH
3606 }
3607
3608#ifdef COFF_WITH_PE
3609 /* PE stores COMDAT section information in the symbol table. If
3610 this section is supposed to have some COMDAT info, track down
3611 the symbol in the symbol table and modify it. */
3612 if ((current->flags & SEC_LINK_ONCE) != 0)
3613 {
3614 unsigned int i, count;
3615 asymbol **psym;
3616 coff_symbol_type *csym = NULL;
3617 asymbol **psymsec;
3618
3619 psymsec = NULL;
3620 count = bfd_get_symcount (abfd);
3621 for (i = 0, psym = abfd->outsymbols; i < count; i++, psym++)
3622 {
3623 if ((*psym)->section != current)
3624 continue;
3625
3626 /* Remember the location of the first symbol in this
3627 section. */
3628 if (psymsec == NULL)
3629 psymsec = psym;
3630
3631 /* See if this is the section symbol. */
3632 if (strcmp ((*psym)->name, current->name) == 0)
3633 {
3634 csym = coff_symbol_from (abfd, *psym);
3635 if (csym == NULL
3636 || csym->native == NULL
3637 || csym->native->u.syment.n_numaux < 1
3638 || csym->native->u.syment.n_sclass != C_STAT
3639 || csym->native->u.syment.n_type != T_NULL)
3640 continue;
3641
3642 /* Here *PSYM is the section symbol for CURRENT. */
3643
3644 break;
3645 }
3646 }
3647
3648 /* Did we find it?
3649 Note that we might not if we're converting the file from
3650 some other object file format. */
3651 if (i < count)
3652 {
3653 combined_entry_type *aux;
3654
3655 /* We don't touch the x_checksum field. The
3656 x_associated field is not currently supported. */
3657
3658 aux = csym->native + 1;
3659 switch (current->flags & SEC_LINK_DUPLICATES)
3660 {
3661 case SEC_LINK_DUPLICATES_DISCARD:
3662 aux->u.auxent.x_scn.x_comdat = IMAGE_COMDAT_SELECT_ANY;
3663 break;
3664
3665 case SEC_LINK_DUPLICATES_ONE_ONLY:
3666 aux->u.auxent.x_scn.x_comdat =
3667 IMAGE_COMDAT_SELECT_NODUPLICATES;
3668 break;
3669
3670 case SEC_LINK_DUPLICATES_SAME_SIZE:
3671 aux->u.auxent.x_scn.x_comdat =
3672 IMAGE_COMDAT_SELECT_SAME_SIZE;
3673 break;
3674
3675 case SEC_LINK_DUPLICATES_SAME_CONTENTS:
3676 aux->u.auxent.x_scn.x_comdat =
3677 IMAGE_COMDAT_SELECT_EXACT_MATCH;
3678 break;
3679 }
3680
3681 /* The COMDAT symbol must be the first symbol from this
3682 section in the symbol table. In order to make this
3683 work, we move the COMDAT symbol before the first
3684 symbol we found in the search above. It's OK to
3685 rearrange the symbol table at this point, because
3686 coff_renumber_symbols is going to rearrange it
3687 further and fix up all the aux entries. */
3688 if (psym != psymsec)
3689 {
3690 asymbol *hold;
3691 asymbol **pcopy;
3692
3693 hold = *psym;
3694 for (pcopy = psym; pcopy > psymsec; pcopy--)
3695 pcopy[0] = pcopy[-1];
3696 *psymsec = hold;
3697 }
3698 }
3699 }
3700#endif /* COFF_WITH_PE */
3701 }
3702
3703#ifdef RS6000COFF_C
dc810e39 3704#ifndef XCOFF64
252b5132
RH
3705 /* XCOFF handles overflows in the reloc and line number count fields
3706 by creating a new section header to hold the correct values. */
3707 for (current = abfd->sections; current != NULL; current = current->next)
3708 {
3709 if (current->reloc_count >= 0xffff || current->lineno_count >= 0xffff)
3710 {
3711 struct internal_scnhdr scnhdr;
3712 SCNHDR buff;
dc810e39 3713 bfd_size_type amt;
252b5132
RH
3714
3715 internal_f.f_nscns++;
3716 strncpy (&(scnhdr.s_name[0]), current->name, 8);
3717 scnhdr.s_paddr = current->reloc_count;
3718 scnhdr.s_vaddr = current->lineno_count;
3719 scnhdr.s_size = 0;
3720 scnhdr.s_scnptr = 0;
3721 scnhdr.s_relptr = current->rel_filepos;
3722 scnhdr.s_lnnoptr = current->line_filepos;
3723 scnhdr.s_nreloc = current->target_index;
3724 scnhdr.s_nlnno = current->target_index;
3725 scnhdr.s_flags = STYP_OVRFLO;
dc810e39 3726 amt = bfd_coff_scnhsz (abfd);
252b5132 3727 if (coff_swap_scnhdr_out (abfd, &scnhdr, &buff) == 0
7920ce38 3728 || bfd_bwrite (& buff, amt, abfd) != amt)
b34976b6 3729 return FALSE;
252b5132
RH
3730 }
3731 }
beb1bf64 3732#endif
252b5132
RH
3733#endif
3734
e60b52c6 3735 /* OK, now set up the filehdr... */
252b5132
RH
3736
3737 /* Don't include the internal abs section in the section count */
3738
ed781d5d 3739 /* We will NOT put a fucking timestamp in the header here. Every time you
252b5132
RH
3740 put it back, I will come in and take it out again. I'm sorry. This
3741 field does not belong here. We fill it with a 0 so it compares the
ed781d5d 3742 same but is not a reasonable time. -- gnu@cygnus.com */
252b5132 3743 internal_f.f_timdat = 0;
252b5132
RH
3744 internal_f.f_flags = 0;
3745
3746 if (abfd->flags & EXEC_P)
6b3b007b 3747 internal_f.f_opthdr = bfd_coff_aoutsz (abfd);
252b5132
RH
3748 else
3749 {
3750 internal_f.f_opthdr = 0;
3751#ifdef RS6000COFF_C
dc810e39 3752#ifndef XCOFF64
252b5132 3753 if (xcoff_data (abfd)->full_aouthdr)
6b3b007b 3754 internal_f.f_opthdr = bfd_coff_aoutsz (abfd);
252b5132
RH
3755 else
3756 internal_f.f_opthdr = SMALL_AOUTSZ;
dc810e39 3757#endif
252b5132
RH
3758#endif
3759 }
3760
3761 if (!hasrelocs)
3762 internal_f.f_flags |= F_RELFLG;
3763 if (!haslinno)
3764 internal_f.f_flags |= F_LNNO;
3765 if (abfd->flags & EXEC_P)
3766 internal_f.f_flags |= F_EXEC;
4cfec37b
ILT
3767#ifdef COFF_IMAGE_WITH_PE
3768 if (! hasdebug)
3769 internal_f.f_flags |= IMAGE_FILE_DEBUG_STRIPPED;
d70270c5
BF
3770 if (pe_data (abfd)->real_flags & IMAGE_FILE_LARGE_ADDRESS_AWARE)
3771 internal_f.f_flags |= IMAGE_FILE_LARGE_ADDRESS_AWARE;
4cfec37b 3772#endif
252b5132 3773
99ad8390 3774#ifndef COFF_WITH_pex64
bcb9b88d
NC
3775#ifdef COFF_WITH_PE
3776 internal_f.f_flags |= IMAGE_FILE_32BIT_MACHINE;
3777#else
252b5132
RH
3778 if (bfd_little_endian (abfd))
3779 internal_f.f_flags |= F_AR32WR;
3780 else
3781 internal_f.f_flags |= F_AR32W;
8a1ad8e7 3782#endif
99ad8390 3783#endif
252b5132 3784
81635ce4 3785#ifdef TI_TARGET_ID
ed781d5d
NC
3786 /* Target id is used in TI COFF v1 and later; COFF0 won't use this field,
3787 but it doesn't hurt to set it internally. */
81635ce4
TW
3788 internal_f.f_target_id = TI_TARGET_ID;
3789#endif
252b5132
RH
3790#ifdef TIC80_TARGET_ID
3791 internal_f.f_target_id = TIC80_TARGET_ID;
3792#endif
3793
ed781d5d
NC
3794 /* FIXME, should do something about the other byte orders and
3795 architectures. */
252b5132
RH
3796
3797#ifdef RS6000COFF_C
3798 if ((abfd->flags & DYNAMIC) != 0)
3799 internal_f.f_flags |= F_SHROBJ;
3800 if (bfd_get_section_by_name (abfd, _LOADER) != NULL)
3801 internal_f.f_flags |= F_DYNLOAD;
3802#endif
3803
3804 memset (&internal_a, 0, sizeof internal_a);
3805
ed781d5d 3806 /* Set up architecture-dependent stuff. */
252b5132
RH
3807 {
3808 unsigned int magic = 0;
3809 unsigned short flags = 0;
ed781d5d 3810
252b5132
RH
3811 coff_set_flags (abfd, &magic, &flags);
3812 internal_f.f_magic = magic;
3813 internal_f.f_flags |= flags;
e60b52c6 3814 /* ...and the "opt"hdr... */
252b5132 3815
81635ce4
TW
3816#ifdef TICOFF_AOUT_MAGIC
3817 internal_a.magic = TICOFF_AOUT_MAGIC;
3818#define __A_MAGIC_SET__
3819#endif
252b5132
RH
3820#ifdef TIC80COFF
3821 internal_a.magic = TIC80_ARCH_MAGIC;
3822#define __A_MAGIC_SET__
3823#endif /* TIC80 */
3824#ifdef I860
3825 /* FIXME: What are the a.out magic numbers for the i860? */
3826 internal_a.magic = 0;
3827#define __A_MAGIC_SET__
3828#endif /* I860 */
3829#ifdef I960
3830 internal_a.magic = (magic == I960ROMAGIC ? NMAGIC : OMAGIC);
3831#define __A_MAGIC_SET__
3832#endif /* I960 */
3833#if M88
3834#define __A_MAGIC_SET__
3835 internal_a.magic = PAGEMAGICBCS;
3836#endif /* M88 */
3837
3838#if APOLLO_M68
3839#define __A_MAGIC_SET__
3840 internal_a.magic = APOLLO_COFF_VERSION_NUMBER;
3841#endif
3842
3843#if defined(M68) || defined(WE32K) || defined(M68K)
3844#define __A_MAGIC_SET__
3845#if defined(LYNXOS)
3846 internal_a.magic = LYNXCOFFMAGIC;
3847#else
3848#if defined(TARG_AUX)
3849 internal_a.magic = (abfd->flags & D_PAGED ? PAGEMAGICPEXECPAGED :
3850 abfd->flags & WP_TEXT ? PAGEMAGICPEXECSWAPPED :
3851 PAGEMAGICEXECSWAPPED);
3852#else
3853#if defined (PAGEMAGICPEXECPAGED)
3854 internal_a.magic = PAGEMAGICPEXECPAGED;
3855#endif
3856#endif /* TARG_AUX */
3857#endif /* LYNXOS */
3858#endif /* M68 || WE32K || M68K */
3859
3860#if defined(ARM)
3861#define __A_MAGIC_SET__
3862 internal_a.magic = ZMAGIC;
e60b52c6 3863#endif
252b5132
RH
3864
3865#if defined(PPC_PE)
3866#define __A_MAGIC_SET__
3867 internal_a.magic = IMAGE_NT_OPTIONAL_HDR_MAGIC;
3868#endif
3869
3870#if defined MCORE_PE
3871#define __A_MAGIC_SET__
3872 internal_a.magic = IMAGE_NT_OPTIONAL_HDR_MAGIC;
e60b52c6 3873#endif
252b5132
RH
3874
3875#if defined(I386)
3876#define __A_MAGIC_SET__
99ad8390 3877#if defined LYNXOS
252b5132 3878 internal_a.magic = LYNXCOFFMAGIC;
99ad8390
NC
3879#elif defined AMD64
3880 internal_a.magic = IMAGE_NT_OPTIONAL_HDR64_MAGIC;
3881#else
252b5132 3882 internal_a.magic = ZMAGIC;
99ad8390 3883#endif
252b5132
RH
3884#endif /* I386 */
3885
fac41780
JW
3886#if defined(IA64)
3887#define __A_MAGIC_SET__
7a2ec0a6 3888 internal_a.magic = PE32PMAGIC;
fac41780
JW
3889#endif /* IA64 */
3890
252b5132
RH
3891#if defined(SPARC)
3892#define __A_MAGIC_SET__
3893#if defined(LYNXOS)
3894 internal_a.magic = LYNXCOFFMAGIC;
3895#endif /* LYNXOS */
3896#endif /* SPARC */
3897
3898#ifdef RS6000COFF_C
3899#define __A_MAGIC_SET__
3900 internal_a.magic = (abfd->flags & D_PAGED) ? RS6K_AOUTHDR_ZMAGIC :
3901 (abfd->flags & WP_TEXT) ? RS6K_AOUTHDR_NMAGIC :
3902 RS6K_AOUTHDR_OMAGIC;
3903#endif
3904
17505c5c
NC
3905#if defined(SH) && defined(COFF_WITH_PE)
3906#define __A_MAGIC_SET__
3907 internal_a.magic = SH_PE_MAGIC;
3908#endif
3909
3910#if defined(MIPS) && defined(COFF_WITH_PE)
3911#define __A_MAGIC_SET__
3912 internal_a.magic = MIPS_PE_MAGIC;
3913#endif
3914
3b16e843
NC
3915#ifdef OR32
3916#define __A_MAGIC_SET__
3917 internal_a.magic = NMAGIC; /* Assume separate i/d. */
3918#endif
3919
7499d566
NC
3920#ifdef MAXQ20MAGIC
3921#define __A_MAGIC_SET__
3922 internal_a.magic = MAXQ20MAGIC;
3923#endif
3924
252b5132
RH
3925#ifndef __A_MAGIC_SET__
3926#include "Your aouthdr magic number is not being set!"
3927#else
3928#undef __A_MAGIC_SET__
3929#endif
3930 }
3931
3932 /* FIXME: Does anybody ever set this to another value? */
3933 internal_a.vstamp = 0;
3934
ed781d5d 3935 /* Now should write relocs, strings, syms. */
252b5132
RH
3936 obj_sym_filepos (abfd) = sym_base;
3937
3938 if (bfd_get_symcount (abfd) != 0)
3939 {
3940 int firstundef;
0e71e495 3941
252b5132 3942 if (!coff_renumber_symbols (abfd, &firstundef))
b34976b6 3943 return FALSE;
252b5132
RH
3944 coff_mangle_symbols (abfd);
3945 if (! coff_write_symbols (abfd))
b34976b6 3946 return FALSE;
252b5132 3947 if (! coff_write_linenumbers (abfd))
b34976b6 3948 return FALSE;
252b5132 3949 if (! coff_write_relocs (abfd, firstundef))
b34976b6 3950 return FALSE;
252b5132
RH
3951 }
3952#ifdef COFF_LONG_SECTION_NAMES
d71f672e 3953 else if (long_section_names && ! obj_coff_strings_written (abfd))
252b5132
RH
3954 {
3955 /* If we have long section names we have to write out the string
3956 table even if there are no symbols. */
3957 if (! coff_write_symbols (abfd))
b34976b6 3958 return FALSE;
252b5132
RH
3959 }
3960#endif
3961#ifdef COFF_IMAGE_WITH_PE
3962#ifdef PPC_PE
3963 else if ((abfd->flags & EXEC_P) != 0)
3964 {
3965 bfd_byte b;
3966
3967 /* PowerPC PE appears to require that all executable files be
3968 rounded up to the page size. */
3969 b = 0;
3970 if (bfd_seek (abfd,
dc810e39 3971 (file_ptr) BFD_ALIGN (sym_base, COFF_PAGE_SIZE) - 1,
252b5132 3972 SEEK_SET) != 0
dc810e39 3973 || bfd_bwrite (&b, (bfd_size_type) 1, abfd) != 1)
b34976b6 3974 return FALSE;
252b5132
RH
3975 }
3976#endif
3977#endif
3978
3979 /* If bfd_get_symcount (abfd) != 0, then we are not using the COFF
3980 backend linker, and obj_raw_syment_count is not valid until after
3981 coff_write_symbols is called. */
3982 if (obj_raw_syment_count (abfd) != 0)
3983 {
3984 internal_f.f_symptr = sym_base;
3985#ifdef RS6000COFF_C
3986 /* AIX appears to require that F_RELFLG not be set if there are
3987 local symbols but no relocations. */
3988 internal_f.f_flags &=~ F_RELFLG;
3989#endif
3990 }
3991 else
3992 {
3993 if (long_section_names)
3994 internal_f.f_symptr = sym_base;
3995 else
3996 internal_f.f_symptr = 0;
3997 internal_f.f_flags |= F_LSYMS;
3998 }
3999
4000 if (text_sec)
4001 {
eea6121a 4002 internal_a.tsize = text_sec->size;
252b5132
RH
4003 internal_a.text_start = internal_a.tsize ? text_sec->vma : 0;
4004 }
4005 if (data_sec)
4006 {
eea6121a 4007 internal_a.dsize = data_sec->size;
252b5132
RH
4008 internal_a.data_start = internal_a.dsize ? data_sec->vma : 0;
4009 }
4010 if (bss_sec)
4011 {
eea6121a 4012 internal_a.bsize = bss_sec->size;
252b5132
RH
4013 if (internal_a.bsize && bss_sec->vma < internal_a.data_start)
4014 internal_a.data_start = bss_sec->vma;
4015 }
4016
4017 internal_a.entry = bfd_get_start_address (abfd);
4018 internal_f.f_nsyms = obj_raw_syment_count (abfd);
4019
4020#ifdef RS6000COFF_C
4021 if (xcoff_data (abfd)->full_aouthdr)
4022 {
4023 bfd_vma toc;
4024 asection *loader_sec;
4025
4026 internal_a.vstamp = 1;
4027
4028 internal_a.o_snentry = xcoff_data (abfd)->snentry;
4029 if (internal_a.o_snentry == 0)
4030 internal_a.entry = (bfd_vma) -1;
4031
4032 if (text_sec != NULL)
4033 {
4034 internal_a.o_sntext = text_sec->target_index;
4035 internal_a.o_algntext = bfd_get_section_alignment (abfd, text_sec);
4036 }
4037 else
4038 {
4039 internal_a.o_sntext = 0;
4040 internal_a.o_algntext = 0;
4041 }
4042 if (data_sec != NULL)
4043 {
4044 internal_a.o_sndata = data_sec->target_index;
4045 internal_a.o_algndata = bfd_get_section_alignment (abfd, data_sec);
4046 }
4047 else
4048 {
4049 internal_a.o_sndata = 0;
4050 internal_a.o_algndata = 0;
4051 }
4052 loader_sec = bfd_get_section_by_name (abfd, ".loader");
4053 if (loader_sec != NULL)
4054 internal_a.o_snloader = loader_sec->target_index;
4055 else
4056 internal_a.o_snloader = 0;
4057 if (bss_sec != NULL)
4058 internal_a.o_snbss = bss_sec->target_index;
4059 else
4060 internal_a.o_snbss = 0;
4061
4062 toc = xcoff_data (abfd)->toc;
4063 internal_a.o_toc = toc;
4064 internal_a.o_sntoc = xcoff_data (abfd)->sntoc;
4065
4066 internal_a.o_modtype = xcoff_data (abfd)->modtype;
4067 if (xcoff_data (abfd)->cputype != -1)
4068 internal_a.o_cputype = xcoff_data (abfd)->cputype;
4069 else
4070 {
4071 switch (bfd_get_arch (abfd))
4072 {
4073 case bfd_arch_rs6000:
4074 internal_a.o_cputype = 4;
4075 break;
4076 case bfd_arch_powerpc:
250d94fd 4077 if (bfd_get_mach (abfd) == bfd_mach_ppc)
252b5132
RH
4078 internal_a.o_cputype = 3;
4079 else
4080 internal_a.o_cputype = 1;
4081 break;
4082 default:
4083 abort ();
4084 }
4085 }
4086 internal_a.o_maxstack = xcoff_data (abfd)->maxstack;
4087 internal_a.o_maxdata = xcoff_data (abfd)->maxdata;
4088 }
4089#endif
4090
7920ce38 4091 /* Now write them. */
252b5132 4092 if (bfd_seek (abfd, (file_ptr) 0, SEEK_SET) != 0)
b34976b6 4093 return FALSE;
e60b52c6 4094
252b5132 4095 {
b5f303f0 4096 char * buff;
dc810e39 4097 bfd_size_type amount = bfd_coff_filhsz (abfd);
e60b52c6 4098
dc810e39 4099 buff = bfd_malloc (amount);
e60b52c6 4100 if (buff == NULL)
b34976b6 4101 return FALSE;
e60b52c6 4102
7920ce38
NC
4103 bfd_coff_swap_filehdr_out (abfd, & internal_f, buff);
4104 amount = bfd_bwrite (buff, amount, abfd);
e60b52c6 4105
2fca4467 4106 free (buff);
e60b52c6 4107
b5f303f0 4108 if (amount != bfd_coff_filhsz (abfd))
b34976b6 4109 return FALSE;
252b5132 4110 }
e60b52c6 4111
252b5132
RH
4112 if (abfd->flags & EXEC_P)
4113 {
e60b52c6 4114 /* Note that peicode.h fills in a PEAOUTHDR, not an AOUTHDR.
ed781d5d 4115 include/coff/pe.h sets AOUTSZ == sizeof (PEAOUTHDR)). */
b5f303f0 4116 char * buff;
dc810e39 4117 bfd_size_type amount = bfd_coff_aoutsz (abfd);
b5f303f0 4118
dc810e39 4119 buff = bfd_malloc (amount);
e60b52c6 4120 if (buff == NULL)
b34976b6 4121 return FALSE;
e60b52c6 4122
7920ce38
NC
4123 coff_swap_aouthdr_out (abfd, & internal_a, buff);
4124 amount = bfd_bwrite (buff, amount, abfd);
e60b52c6 4125
2fca4467 4126 free (buff);
e60b52c6 4127
b5f303f0 4128 if (amount != bfd_coff_aoutsz (abfd))
b34976b6 4129 return FALSE;
05793179
NC
4130
4131#ifdef COFF_IMAGE_WITH_PE
4132 if (! coff_apply_checksum (abfd))
b34976b6 4133 return FALSE;
05793179 4134#endif
252b5132
RH
4135 }
4136#ifdef RS6000COFF_C
4137 else
4138 {
4139 AOUTHDR buff;
4140 size_t size;
4141
4142 /* XCOFF seems to always write at least a small a.out header. */
7920ce38 4143 coff_swap_aouthdr_out (abfd, & internal_a, & buff);
252b5132 4144 if (xcoff_data (abfd)->full_aouthdr)
6b3b007b 4145 size = bfd_coff_aoutsz (abfd);
252b5132
RH
4146 else
4147 size = SMALL_AOUTSZ;
7920ce38 4148 if (bfd_bwrite (& buff, (bfd_size_type) size, abfd) != size)
b34976b6 4149 return FALSE;
252b5132
RH
4150 }
4151#endif
4152
b34976b6 4153 return TRUE;
252b5132
RH
4154}
4155
b34976b6 4156static bfd_boolean
7920ce38
NC
4157coff_set_section_contents (bfd * abfd,
4158 sec_ptr section,
4159 const void * location,
4160 file_ptr offset,
4161 bfd_size_type count)
252b5132 4162{
ed781d5d 4163 if (! abfd->output_has_begun) /* Set by bfd.c handler. */
252b5132
RH
4164 {
4165 if (! coff_compute_section_file_positions (abfd))
b34976b6 4166 return FALSE;
252b5132
RH
4167 }
4168
4169#if defined(_LIB) && !defined(TARG_AUX)
252b5132
RH
4170 /* The physical address field of a .lib section is used to hold the
4171 number of shared libraries in the section. This code counts the
4172 number of sections being written, and increments the lma field
4173 with the number.
4174
4175 I have found no documentation on the contents of this section.
4176 Experimentation indicates that the section contains zero or more
4177 records, each of which has the following structure:
4178
4179 - a (four byte) word holding the length of this record, in words,
4180 - a word that always seems to be set to "2",
4181 - the path to a shared library, null-terminated and then padded
4182 to a whole word boundary.
4183
4184 bfd_assert calls have been added to alert if an attempt is made
4185 to write a section which doesn't follow these assumptions. The
4186 code has been tested on ISC 4.1 by me, and on SCO by Robert Lipe
4187 <robertl@arnet.com> (Thanks!).
e60b52c6 4188
ed781d5d 4189 Gvran Uddeborg <gvran@uddeborg.pp.se>. */
252b5132
RH
4190 if (strcmp (section->name, _LIB) == 0)
4191 {
4192 bfd_byte *rec, *recend;
4193
4194 rec = (bfd_byte *) location;
4195 recend = rec + count;
4196 while (rec < recend)
4197 {
4198 ++section->lma;
4199 rec += bfd_get_32 (abfd, rec) * 4;
4200 }
4201
4202 BFD_ASSERT (rec == recend);
4203 }
252b5132
RH
4204#endif
4205
4206 /* Don't write out bss sections - one way to do this is to
e60b52c6 4207 see if the filepos has not been set. */
252b5132 4208 if (section->filepos == 0)
b34976b6 4209 return TRUE;
252b5132 4210
dc810e39 4211 if (bfd_seek (abfd, section->filepos + offset, SEEK_SET) != 0)
b34976b6 4212 return FALSE;
252b5132 4213
dc810e39 4214 if (count == 0)
b34976b6 4215 return TRUE;
dc810e39
AM
4216
4217 return bfd_bwrite (location, count, abfd) == count;
252b5132 4218}
252b5132 4219
7920ce38
NC
4220static void *
4221buy_and_read (bfd *abfd, file_ptr where, bfd_size_type size)
252b5132 4222{
7920ce38
NC
4223 void * area = bfd_alloc (abfd, size);
4224
252b5132
RH
4225 if (!area)
4226 return (NULL);
dc810e39
AM
4227 if (bfd_seek (abfd, where, SEEK_SET) != 0
4228 || bfd_bread (area, size, abfd) != size)
252b5132
RH
4229 return (NULL);
4230 return (area);
7920ce38 4231}
252b5132
RH
4232
4233/*
4234SUBSUBSECTION
4235 Reading linenumbers
4236
4237 Creating the linenumber table is done by reading in the entire
4238 coff linenumber table, and creating another table for internal use.
4239
4240 A coff linenumber table is structured so that each function
4241 is marked as having a line number of 0. Each line within the
4242 function is an offset from the first line in the function. The
4243 base of the line number information for the table is stored in
4244 the symbol associated with the function.
4245
00692651
ILT
4246 Note: The PE format uses line number 0 for a flag indicating a
4247 new source file.
4248
252b5132
RH
4249 The information is copied from the external to the internal
4250 table, and each symbol which marks a function is marked by
4251 pointing its...
4252
4253 How does this work ?
252b5132
RH
4254*/
4255
b34976b6 4256static bfd_boolean
7920ce38 4257coff_slurp_line_table (bfd *abfd, asection *asect)
252b5132
RH
4258{
4259 LINENO *native_lineno;
4260 alent *lineno_cache;
dc810e39 4261 bfd_size_type amt;
252b5132 4262
7920ce38 4263 BFD_ASSERT (asect->lineno == NULL);
252b5132 4264
dc810e39
AM
4265 amt = (bfd_size_type) bfd_coff_linesz (abfd) * asect->lineno_count;
4266 native_lineno = (LINENO *) buy_and_read (abfd, asect->line_filepos, amt);
14abcef9
NC
4267 if (native_lineno == NULL)
4268 {
4269 (*_bfd_error_handler)
d003868e 4270 (_("%B: warning: line number table read failed"), abfd);
14abcef9
NC
4271 return FALSE;
4272 }
dc810e39 4273 amt = ((bfd_size_type) asect->lineno_count + 1) * sizeof (alent);
7920ce38 4274 lineno_cache = bfd_alloc (abfd, amt);
252b5132 4275 if (lineno_cache == NULL)
b34976b6 4276 return FALSE;
252b5132
RH
4277 else
4278 {
4279 unsigned int counter = 0;
4280 alent *cache_ptr = lineno_cache;
4281 LINENO *src = native_lineno;
4282
4283 while (counter < asect->lineno_count)
4284 {
4285 struct internal_lineno dst;
ed781d5d 4286
7f6d05e8 4287 bfd_coff_swap_lineno_in (abfd, src, &dst);
252b5132
RH
4288 cache_ptr->line_number = dst.l_lnno;
4289
4290 if (cache_ptr->line_number == 0)
4291 {
b34976b6 4292 bfd_boolean warned;
beb1bf64 4293 bfd_signed_vma symndx;
252b5132
RH
4294 coff_symbol_type *sym;
4295
b34976b6 4296 warned = FALSE;
252b5132
RH
4297 symndx = dst.l_addr.l_symndx;
4298 if (symndx < 0
beb1bf64 4299 || (bfd_vma) symndx >= obj_raw_syment_count (abfd))
252b5132
RH
4300 {
4301 (*_bfd_error_handler)
d003868e
AM
4302 (_("%B: warning: illegal symbol index %ld in line numbers"),
4303 abfd, dst.l_addr.l_symndx);
252b5132 4304 symndx = 0;
b34976b6 4305 warned = TRUE;
252b5132
RH
4306 }
4307 /* FIXME: We should not be casting between ints and
4308 pointers like this. */
4309 sym = ((coff_symbol_type *)
4310 ((symndx + obj_raw_syments (abfd))
4311 ->u.syment._n._n_n._n_zeroes));
4312 cache_ptr->u.sym = (asymbol *) sym;
4313 if (sym->lineno != NULL && ! warned)
4314 {
4315 (*_bfd_error_handler)
d003868e
AM
4316 (_("%B: warning: duplicate line number information for `%s'"),
4317 abfd, bfd_asymbol_name (&sym->symbol));
252b5132
RH
4318 }
4319 sym->lineno = cache_ptr;
4320 }
4321 else
7920ce38
NC
4322 cache_ptr->u.offset = dst.l_addr.l_paddr
4323 - bfd_section_vma (abfd, asect);
252b5132
RH
4324
4325 cache_ptr++;
4326 src++;
4327 counter++;
4328 }
4329 cache_ptr->line_number = 0;
4330
4331 }
4332 asect->lineno = lineno_cache;
e60b52c6 4333 /* FIXME, free native_lineno here, or use alloca or something. */
b34976b6 4334 return TRUE;
252b5132
RH
4335}
4336
00692651
ILT
4337/* Slurp in the symbol table, converting it to generic form. Note
4338 that if coff_relocate_section is defined, the linker will read
4339 symbols via coff_link_add_symbols, rather than via this routine. */
4340
b34976b6 4341static bfd_boolean
7920ce38 4342coff_slurp_symbol_table (bfd * abfd)
252b5132
RH
4343{
4344 combined_entry_type *native_symbols;
4345 coff_symbol_type *cached_area;
4346 unsigned int *table_ptr;
dc810e39 4347 bfd_size_type amt;
252b5132
RH
4348 unsigned int number_of_symbols = 0;
4349
4350 if (obj_symbols (abfd))
b34976b6 4351 return TRUE;
252b5132 4352
ed781d5d 4353 /* Read in the symbol table. */
252b5132 4354 if ((native_symbols = coff_get_normalized_symtab (abfd)) == NULL)
ed781d5d 4355 return FALSE;
252b5132 4356
ed781d5d 4357 /* Allocate enough room for all the symbols in cached form. */
dc810e39
AM
4358 amt = obj_raw_syment_count (abfd);
4359 amt *= sizeof (coff_symbol_type);
7920ce38 4360 cached_area = bfd_alloc (abfd, amt);
252b5132 4361 if (cached_area == NULL)
b34976b6 4362 return FALSE;
dc810e39
AM
4363
4364 amt = obj_raw_syment_count (abfd);
4365 amt *= sizeof (unsigned int);
7920ce38 4366 table_ptr = bfd_alloc (abfd, amt);
252b5132
RH
4367
4368 if (table_ptr == NULL)
b34976b6 4369 return FALSE;
252b5132
RH
4370 else
4371 {
4372 coff_symbol_type *dst = cached_area;
4373 unsigned int last_native_index = obj_raw_syment_count (abfd);
4374 unsigned int this_index = 0;
ed781d5d 4375
252b5132
RH
4376 while (this_index < last_native_index)
4377 {
4378 combined_entry_type *src = native_symbols + this_index;
4379 table_ptr[this_index] = number_of_symbols;
4380 dst->symbol.the_bfd = abfd;
4381
4382 dst->symbol.name = (char *) (src->u.syment._n._n_n._n_offset);
4383 /* We use the native name field to point to the cached field. */
4384 src->u.syment._n._n_n._n_zeroes = (long) dst;
4385 dst->symbol.section = coff_section_from_bfd_index (abfd,
4386 src->u.syment.n_scnum);
4387 dst->symbol.flags = 0;
b34976b6 4388 dst->done_lineno = FALSE;
252b5132
RH
4389
4390 switch (src->u.syment.n_sclass)
4391 {
4392#ifdef I960
4393 case C_LEAFEXT:
ed781d5d 4394 /* Fall through to next case. */
252b5132
RH
4395#endif
4396
4397 case C_EXT:
4398 case C_WEAKEXT:
4399#if defined ARM
4400 case C_THUMBEXT:
4401 case C_THUMBEXTFUNC:
4402#endif
4403#ifdef RS6000COFF_C
4404 case C_HIDEXT:
4405#endif
4406#ifdef C_SYSTEM
ed781d5d 4407 case C_SYSTEM: /* System Wide variable. */
252b5132
RH
4408#endif
4409#ifdef COFF_WITH_PE
ed781d5d 4410 /* In PE, 0x68 (104) denotes a section symbol. */
252b5132 4411 case C_SECTION:
5d54c628 4412 /* In PE, 0x69 (105) denotes a weak external symbol. */
252b5132
RH
4413 case C_NT_WEAK:
4414#endif
5d54c628 4415 switch (coff_classify_symbol (abfd, &src->u.syment))
252b5132 4416 {
5d54c628 4417 case COFF_SYMBOL_GLOBAL:
252b5132 4418 dst->symbol.flags = BSF_EXPORT | BSF_GLOBAL;
252b5132
RH
4419#if defined COFF_WITH_PE
4420 /* PE sets the symbol to a value relative to the
4421 start of the section. */
4422 dst->symbol.value = src->u.syment.n_value;
4423#else
4424 dst->symbol.value = (src->u.syment.n_value
4425 - dst->symbol.section->vma);
4426#endif
252b5132 4427 if (ISFCN ((src->u.syment.n_type)))
7920ce38
NC
4428 /* A function ext does not go at the end of a
4429 file. */
4430 dst->symbol.flags |= BSF_NOT_AT_END | BSF_FUNCTION;
5d54c628
ILT
4431 break;
4432
4433 case COFF_SYMBOL_COMMON:
4434 dst->symbol.section = bfd_com_section_ptr;
4435 dst->symbol.value = src->u.syment.n_value;
4436 break;
4437
4438 case COFF_SYMBOL_UNDEFINED:
4439 dst->symbol.section = bfd_und_section_ptr;
4440 dst->symbol.value = 0;
e60b52c6 4441 break;
5d54c628
ILT
4442
4443 case COFF_SYMBOL_PE_SECTION:
4444 dst->symbol.flags |= BSF_EXPORT | BSF_SECTION_SYM;
4445 dst->symbol.value = 0;
4446 break;
4447
4448 case COFF_SYMBOL_LOCAL:
4449 dst->symbol.flags = BSF_LOCAL;
4450#if defined COFF_WITH_PE
4451 /* PE sets the symbol to a value relative to the
4452 start of the section. */
4453 dst->symbol.value = src->u.syment.n_value;
4454#else
4455 dst->symbol.value = (src->u.syment.n_value
4456 - dst->symbol.section->vma);
4457#endif
4458 if (ISFCN ((src->u.syment.n_type)))
4459 dst->symbol.flags |= BSF_NOT_AT_END | BSF_FUNCTION;
4460 break;
252b5132
RH
4461 }
4462
4463#ifdef RS6000COFF_C
252b5132
RH
4464 /* A symbol with a csect entry should not go at the end. */
4465 if (src->u.syment.n_numaux > 0)
4466 dst->symbol.flags |= BSF_NOT_AT_END;
4467#endif
4468
4469#ifdef COFF_WITH_PE
4470 if (src->u.syment.n_sclass == C_NT_WEAK)
a181be0a
NC
4471 dst->symbol.flags |= BSF_WEAK;
4472
ec0ef80e
DD
4473 if (src->u.syment.n_sclass == C_SECTION
4474 && src->u.syment.n_scnum > 0)
eb1e0e80 4475 dst->symbol.flags = BSF_LOCAL;
252b5132 4476#endif
252b5132 4477 if (src->u.syment.n_sclass == C_WEAKEXT)
a181be0a 4478 dst->symbol.flags |= BSF_WEAK;
252b5132
RH
4479
4480 break;
4481
ed781d5d 4482 case C_STAT: /* Static. */
252b5132 4483#ifdef I960
ed781d5d 4484 case C_LEAFSTAT: /* Static leaf procedure. */
252b5132 4485#endif
e60b52c6 4486#if defined ARM
ed781d5d
NC
4487 case C_THUMBSTAT: /* Thumb static. */
4488 case C_THUMBLABEL: /* Thumb label. */
4489 case C_THUMBSTATFUNC:/* Thumb static function. */
252b5132 4490#endif
ed781d5d 4491 case C_LABEL: /* Label. */
00692651 4492 if (src->u.syment.n_scnum == N_DEBUG)
252b5132
RH
4493 dst->symbol.flags = BSF_DEBUGGING;
4494 else
4495 dst->symbol.flags = BSF_LOCAL;
4496
4497 /* Base the value as an index from the base of the
4498 section, if there is one. */
4499 if (dst->symbol.section)
4500 {
4501#if defined COFF_WITH_PE
4502 /* PE sets the symbol to a value relative to the
4503 start of the section. */
4504 dst->symbol.value = src->u.syment.n_value;
4505#else
4506 dst->symbol.value = (src->u.syment.n_value
4507 - dst->symbol.section->vma);
4508#endif
4509 }
4510 else
4511 dst->symbol.value = src->u.syment.n_value;
4512 break;
4513
ed781d5d
NC
4514 case C_MOS: /* Member of structure. */
4515 case C_EOS: /* End of structure. */
ed781d5d
NC
4516 case C_REGPARM: /* Register parameter. */
4517 case C_REG: /* register variable. */
5c4491d3 4518 /* C_AUTOARG conflicts with TI COFF C_UEXT. */
81635ce4 4519#if !defined (TIC80COFF) && !defined (TICOFF)
252b5132 4520#ifdef C_AUTOARG
ed781d5d 4521 case C_AUTOARG: /* 960-specific storage class. */
252b5132
RH
4522#endif
4523#endif
ed781d5d 4524 case C_TPDEF: /* Type definition. */
252b5132 4525 case C_ARG:
ed781d5d
NC
4526 case C_AUTO: /* Automatic variable. */
4527 case C_FIELD: /* Bit field. */
4528 case C_ENTAG: /* Enumeration tag. */
4529 case C_MOE: /* Member of enumeration. */
4530 case C_MOU: /* Member of union. */
4531 case C_UNTAG: /* Union tag. */
252b5132
RH
4532 dst->symbol.flags = BSF_DEBUGGING;
4533 dst->symbol.value = (src->u.syment.n_value);
4534 break;
4535
ed781d5d
NC
4536 case C_FILE: /* File name. */
4537 case C_STRTAG: /* Structure tag. */
252b5132
RH
4538#ifdef RS6000COFF_C
4539 case C_GSYM:
4540 case C_LSYM:
4541 case C_PSYM:
4542 case C_RSYM:
4543 case C_RPSYM:
4544 case C_STSYM:
f9f3cf65 4545 case C_TCSYM:
252b5132 4546 case C_BCOMM:
f9f3cf65 4547 case C_ECOML:
252b5132
RH
4548 case C_ECOMM:
4549 case C_DECL:
4550 case C_ENTRY:
4551 case C_FUN:
4552 case C_ESTAT:
4553#endif
4554 dst->symbol.flags = BSF_DEBUGGING;
4555 dst->symbol.value = (src->u.syment.n_value);
4556 break;
4557
4558#ifdef RS6000COFF_C
ed781d5d
NC
4559 case C_BINCL: /* Beginning of include file. */
4560 case C_EINCL: /* Ending of include file. */
252b5132
RH
4561 /* The value is actually a pointer into the line numbers
4562 of the file. We locate the line number entry, and
4563 set the section to the section which contains it, and
4564 the value to the index in that section. */
4565 {
4566 asection *sec;
4567
4568 dst->symbol.flags = BSF_DEBUGGING;
4569 for (sec = abfd->sections; sec != NULL; sec = sec->next)
4570 if (sec->line_filepos <= (file_ptr) src->u.syment.n_value
4571 && ((file_ptr) (sec->line_filepos
6b3b007b 4572 + sec->lineno_count * bfd_coff_linesz (abfd))
252b5132
RH
4573 > (file_ptr) src->u.syment.n_value))
4574 break;
4575 if (sec == NULL)
4576 dst->symbol.value = 0;
4577 else
4578 {
4579 dst->symbol.section = sec;
4580 dst->symbol.value = ((src->u.syment.n_value
4581 - sec->line_filepos)
6b3b007b 4582 / bfd_coff_linesz (abfd));
252b5132
RH
4583 src->fix_line = 1;
4584 }
4585 }
4586 break;
4587
4588 case C_BSTAT:
4589 dst->symbol.flags = BSF_DEBUGGING;
4590
4591 /* The value is actually a symbol index. Save a pointer
4592 to the symbol instead of the index. FIXME: This
4593 should use a union. */
4594 src->u.syment.n_value =
4595 (long) (native_symbols + src->u.syment.n_value);
4596 dst->symbol.value = src->u.syment.n_value;
4597 src->fix_value = 1;
4598 break;
4599#endif
4600
ed781d5d
NC
4601 case C_BLOCK: /* ".bb" or ".eb". */
4602 case C_FCN: /* ".bf" or ".ef" (or PE ".lf"). */
4603 case C_EFCN: /* Physical end of function. */
252b5132
RH
4604#if defined COFF_WITH_PE
4605 /* PE sets the symbol to a value relative to the start
4606 of the section. */
4607 dst->symbol.value = src->u.syment.n_value;
d510f9a6
ILT
4608 if (strcmp (dst->symbol.name, ".bf") != 0)
4609 {
4610 /* PE uses funny values for .ef and .lf; don't
4611 relocate them. */
4612 dst->symbol.flags = BSF_DEBUGGING;
4613 }
4614 else
4615 dst->symbol.flags = BSF_DEBUGGING | BSF_DEBUGGING_RELOC;
252b5132
RH
4616#else
4617 /* Base the value as an index from the base of the
4618 section. */
d510f9a6 4619 dst->symbol.flags = BSF_LOCAL;
252b5132
RH
4620 dst->symbol.value = (src->u.syment.n_value
4621 - dst->symbol.section->vma);
4622#endif
4623 break;
4624
ed781d5d 4625 case C_STATLAB: /* Static load time label. */
34cbe64e
TW
4626 dst->symbol.value = src->u.syment.n_value;
4627 dst->symbol.flags = BSF_GLOBAL;
4628 break;
4629
252b5132 4630 case C_NULL:
00692651
ILT
4631 /* PE DLLs sometimes have zeroed out symbols for some
4632 reason. Just ignore them without a warning. */
4633 if (src->u.syment.n_type == 0
4634 && src->u.syment.n_value == 0
4635 && src->u.syment.n_scnum == 0)
4636 break;
4637 /* Fall through. */
ed781d5d
NC
4638 case C_EXTDEF: /* External definition. */
4639 case C_ULABEL: /* Undefined label. */
4640 case C_USTATIC: /* Undefined static. */
252b5132
RH
4641#ifndef COFF_WITH_PE
4642 /* C_LINE in regular coff is 0x68. NT has taken over this storage
ed781d5d
NC
4643 class to represent a section symbol. */
4644 case C_LINE: /* line # reformatted as symbol table entry. */
252b5132 4645 /* NT uses 0x67 for a weak symbol, not C_ALIAS. */
ed781d5d 4646 case C_ALIAS: /* Duplicate tag. */
252b5132 4647#endif
ed781d5d 4648 /* New storage classes for TI COFF. */
81635ce4 4649#if defined(TIC80COFF) || defined(TICOFF)
ed781d5d 4650 case C_UEXT: /* Tentative external definition. */
252b5132 4651#endif
ed781d5d
NC
4652 case C_EXTLAB: /* External load time label. */
4653 case C_HIDDEN: /* Ext symbol in dmert public lib. */
252b5132
RH
4654 default:
4655 (*_bfd_error_handler)
d003868e
AM
4656 (_("%B: Unrecognized storage class %d for %s symbol `%s'"),
4657 abfd, src->u.syment.n_sclass,
252b5132
RH
4658 dst->symbol.section->name, dst->symbol.name);
4659 dst->symbol.flags = BSF_DEBUGGING;
4660 dst->symbol.value = (src->u.syment.n_value);
4661 break;
4662 }
4663
252b5132
RH
4664 dst->native = src;
4665
4666 dst->symbol.udata.i = 0;
7920ce38 4667 dst->lineno = NULL;
252b5132
RH
4668 this_index += (src->u.syment.n_numaux) + 1;
4669 dst++;
4670 number_of_symbols++;
ed781d5d
NC
4671 }
4672 }
252b5132
RH
4673
4674 obj_symbols (abfd) = cached_area;
4675 obj_raw_syments (abfd) = native_symbols;
4676
4677 bfd_get_symcount (abfd) = number_of_symbols;
4678 obj_convert (abfd) = table_ptr;
ed781d5d 4679 /* Slurp the line tables for each section too. */
252b5132
RH
4680 {
4681 asection *p;
ed781d5d 4682
252b5132
RH
4683 p = abfd->sections;
4684 while (p)
4685 {
4686 coff_slurp_line_table (abfd, p);
4687 p = p->next;
4688 }
4689 }
ed781d5d 4690
b34976b6 4691 return TRUE;
7920ce38 4692}
252b5132 4693
5d54c628
ILT
4694/* Classify a COFF symbol. A couple of targets have globally visible
4695 symbols which are not class C_EXT, and this handles those. It also
4696 recognizes some special PE cases. */
252b5132 4697
5d54c628 4698static enum coff_symbol_classification
7920ce38
NC
4699coff_classify_symbol (bfd *abfd,
4700 struct internal_syment *syment)
5d54c628
ILT
4701{
4702 /* FIXME: This partially duplicates the switch in
4703 coff_slurp_symbol_table. */
4704 switch (syment->n_sclass)
4705 {
4706 case C_EXT:
4707 case C_WEAKEXT:
252b5132 4708#ifdef I960
5d54c628 4709 case C_LEAFEXT:
252b5132 4710#endif
5d54c628
ILT
4711#ifdef ARM
4712 case C_THUMBEXT:
4713 case C_THUMBEXTFUNC:
252b5132 4714#endif
5d54c628
ILT
4715#ifdef C_SYSTEM
4716 case C_SYSTEM:
252b5132 4717#endif
5d54c628
ILT
4718#ifdef COFF_WITH_PE
4719 case C_NT_WEAK:
4720#endif
4721 if (syment->n_scnum == 0)
4722 {
4723 if (syment->n_value == 0)
4724 return COFF_SYMBOL_UNDEFINED;
4725 else
4726 return COFF_SYMBOL_COMMON;
4727 }
4728 return COFF_SYMBOL_GLOBAL;
4729
4730 default:
4731 break;
4732 }
252b5132 4733
5d54c628
ILT
4734#ifdef COFF_WITH_PE
4735 if (syment->n_sclass == C_STAT)
4736 {
4737 if (syment->n_scnum == 0)
7920ce38
NC
4738 /* The Microsoft compiler sometimes generates these if a
4739 small static function is inlined every time it is used.
4740 The function is discarded, but the symbol table entry
4741 remains. */
4742 return COFF_SYMBOL_LOCAL;
252b5132 4743
0717ebb7 4744#ifdef STRICT_PE_FORMAT
bd826630
ILT
4745 /* This is correct for Microsoft generated objects, but it
4746 breaks gas generated objects. */
5d54c628
ILT
4747 if (syment->n_value == 0)
4748 {
4749 asection *sec;
4750 char buf[SYMNMLEN + 1];
4751
4752 sec = coff_section_from_bfd_index (abfd, syment->n_scnum);
4753 if (sec != NULL
4754 && (strcmp (bfd_get_section_name (abfd, sec),
4755 _bfd_coff_internal_syment_name (abfd, syment, buf))
4756 == 0))
4757 return COFF_SYMBOL_PE_SECTION;
4758 }
bd826630 4759#endif
252b5132 4760
5d54c628
ILT
4761 return COFF_SYMBOL_LOCAL;
4762 }
252b5132 4763
5d54c628
ILT
4764 if (syment->n_sclass == C_SECTION)
4765 {
4766 /* In some cases in a DLL generated by the Microsoft linker, the
4767 n_value field will contain garbage. FIXME: This should
4768 probably be handled by the swapping function instead. */
4769 syment->n_value = 0;
4770 if (syment->n_scnum == 0)
4771 return COFF_SYMBOL_UNDEFINED;
4772 return COFF_SYMBOL_PE_SECTION;
4773 }
4774#endif /* COFF_WITH_PE */
252b5132 4775
5d54c628 4776 /* If it is not a global symbol, we presume it is a local symbol. */
5d54c628
ILT
4777 if (syment->n_scnum == 0)
4778 {
4779 char buf[SYMNMLEN + 1];
252b5132 4780
5d54c628 4781 (*_bfd_error_handler)
d003868e
AM
4782 (_("warning: %B: local symbol `%s' has no section"),
4783 abfd, _bfd_coff_internal_syment_name (abfd, syment, buf));
5d54c628 4784 }
252b5132 4785
5d54c628
ILT
4786 return COFF_SYMBOL_LOCAL;
4787}
252b5132
RH
4788
4789/*
4790SUBSUBSECTION
4791 Reading relocations
4792
4793 Coff relocations are easily transformed into the internal BFD form
4794 (@code{arelent}).
4795
4796 Reading a coff relocation table is done in the following stages:
4797
4798 o Read the entire coff relocation table into memory.
4799
4800 o Process each relocation in turn; first swap it from the
4801 external to the internal form.
4802
4803 o Turn the symbol referenced in the relocation's symbol index
4804 into a pointer into the canonical symbol table.
4805 This table is the same as the one returned by a call to
4806 @code{bfd_canonicalize_symtab}. The back end will call that
4807 routine and save the result if a canonicalization hasn't been done.
4808
4809 o The reloc index is turned into a pointer to a howto
4810 structure, in a back end specific way. For instance, the 386
4811 and 960 use the @code{r_type} to directly produce an index
4812 into a howto table vector; the 88k subtracts a number from the
4813 @code{r_type} field and creates an addend field.
252b5132
RH
4814*/
4815
4816#ifndef CALC_ADDEND
4817#define CALC_ADDEND(abfd, ptr, reloc, cache_ptr) \
4818 { \
7920ce38
NC
4819 coff_symbol_type *coffsym = NULL; \
4820 \
252b5132
RH
4821 if (ptr && bfd_asymbol_bfd (ptr) != abfd) \
4822 coffsym = (obj_symbols (abfd) \
4823 + (cache_ptr->sym_ptr_ptr - symbols)); \
4824 else if (ptr) \
4825 coffsym = coff_symbol_from (abfd, ptr); \
7920ce38 4826 if (coffsym != NULL \
252b5132
RH
4827 && coffsym->native->u.syment.n_scnum == 0) \
4828 cache_ptr->addend = 0; \
4829 else if (ptr && bfd_asymbol_bfd (ptr) == abfd \
7920ce38 4830 && ptr->section != NULL) \
252b5132
RH
4831 cache_ptr->addend = - (ptr->section->vma + ptr->value); \
4832 else \
4833 cache_ptr->addend = 0; \
4834 }
4835#endif
4836
b34976b6 4837static bfd_boolean
7920ce38 4838coff_slurp_reloc_table (bfd * abfd, sec_ptr asect, asymbol ** symbols)
252b5132
RH
4839{
4840 RELOC *native_relocs;
4841 arelent *reloc_cache;
4842 arelent *cache_ptr;
252b5132 4843 unsigned int idx;
dc810e39 4844 bfd_size_type amt;
252b5132
RH
4845
4846 if (asect->relocation)
b34976b6 4847 return TRUE;
252b5132 4848 if (asect->reloc_count == 0)
b34976b6 4849 return TRUE;
252b5132 4850 if (asect->flags & SEC_CONSTRUCTOR)
b34976b6 4851 return TRUE;
252b5132 4852 if (!coff_slurp_symbol_table (abfd))
b34976b6 4853 return FALSE;
7920ce38 4854
dc810e39
AM
4855 amt = (bfd_size_type) bfd_coff_relsz (abfd) * asect->reloc_count;
4856 native_relocs = (RELOC *) buy_and_read (abfd, asect->rel_filepos, amt);
4857 amt = (bfd_size_type) asect->reloc_count * sizeof (arelent);
7920ce38 4858 reloc_cache = bfd_alloc (abfd, amt);
252b5132 4859
a50b2160 4860 if (reloc_cache == NULL || native_relocs == NULL)
b34976b6 4861 return FALSE;
252b5132 4862
252b5132
RH
4863 for (idx = 0; idx < asect->reloc_count; idx++)
4864 {
4865 struct internal_reloc dst;
4866 struct external_reloc *src;
4867#ifndef RELOC_PROCESSING
4868 asymbol *ptr;
4869#endif
4870
4871 cache_ptr = reloc_cache + idx;
4872 src = native_relocs + idx;
4873
40b1c6c5 4874 dst.r_offset = 0;
252b5132
RH
4875 coff_swap_reloc_in (abfd, src, &dst);
4876
4877#ifdef RELOC_PROCESSING
4878 RELOC_PROCESSING (cache_ptr, &dst, symbols, abfd, asect);
4879#else
4880 cache_ptr->address = dst.r_vaddr;
4881
4882 if (dst.r_symndx != -1)
4883 {
4884 if (dst.r_symndx < 0 || dst.r_symndx >= obj_conv_table_size (abfd))
4885 {
4886 (*_bfd_error_handler)
d003868e
AM
4887 (_("%B: warning: illegal symbol index %ld in relocs"),
4888 abfd, dst.r_symndx);
252b5132
RH
4889 cache_ptr->sym_ptr_ptr = bfd_abs_section_ptr->symbol_ptr_ptr;
4890 ptr = NULL;
4891 }
4892 else
4893 {
4894 cache_ptr->sym_ptr_ptr = (symbols
4895 + obj_convert (abfd)[dst.r_symndx]);
4896 ptr = *(cache_ptr->sym_ptr_ptr);
4897 }
4898 }
4899 else
4900 {
4901 cache_ptr->sym_ptr_ptr = bfd_abs_section_ptr->symbol_ptr_ptr;
4902 ptr = NULL;
4903 }
4904
4905 /* The symbols definitions that we have read in have been
4906 relocated as if their sections started at 0. But the offsets
4907 refering to the symbols in the raw data have not been
4908 modified, so we have to have a negative addend to compensate.
4909
ed781d5d 4910 Note that symbols which used to be common must be left alone. */
252b5132 4911
ed781d5d 4912 /* Calculate any reloc addend by looking at the symbol. */
252b5132
RH
4913 CALC_ADDEND (abfd, ptr, dst, cache_ptr);
4914
4915 cache_ptr->address -= asect->vma;
7920ce38 4916 /* !! cache_ptr->section = NULL;*/
252b5132 4917
ed781d5d 4918 /* Fill in the cache_ptr->howto field from dst.r_type. */
252b5132
RH
4919 RTYPE2HOWTO (cache_ptr, &dst);
4920#endif /* RELOC_PROCESSING */
4921
4922 if (cache_ptr->howto == NULL)
4923 {
4924 (*_bfd_error_handler)
d003868e
AM
4925 (_("%B: illegal relocation type %d at address 0x%lx"),
4926 abfd, dst.r_type, (long) dst.r_vaddr);
252b5132 4927 bfd_set_error (bfd_error_bad_value);
b34976b6 4928 return FALSE;
252b5132
RH
4929 }
4930 }
4931
4932 asect->relocation = reloc_cache;
b34976b6 4933 return TRUE;
252b5132
RH
4934}
4935
4936#ifndef coff_rtype_to_howto
4937#ifdef RTYPE2HOWTO
4938
4939/* Get the howto structure for a reloc. This is only used if the file
4940 including this one defines coff_relocate_section to be
4941 _bfd_coff_generic_relocate_section, so it is OK if it does not
4942 always work. It is the responsibility of the including file to
4943 make sure it is reasonable if it is needed. */
4944
252b5132 4945static reloc_howto_type *
7920ce38
NC
4946coff_rtype_to_howto (bfd *abfd ATTRIBUTE_UNUSED,
4947 asection *sec ATTRIBUTE_UNUSED,
4948 struct internal_reloc *rel,
4949 struct coff_link_hash_entry *h ATTRIBUTE_UNUSED,
4950 struct internal_syment *sym ATTRIBUTE_UNUSED,
4951 bfd_vma *addendp ATTRIBUTE_UNUSED)
252b5132
RH
4952{
4953 arelent genrel;
4954
964597d0 4955 genrel.howto = NULL;
252b5132
RH
4956 RTYPE2HOWTO (&genrel, rel);
4957 return genrel.howto;
4958}
4959
4960#else /* ! defined (RTYPE2HOWTO) */
4961
4962#define coff_rtype_to_howto NULL
4963
4964#endif /* ! defined (RTYPE2HOWTO) */
4965#endif /* ! defined (coff_rtype_to_howto) */
4966
4967/* This is stupid. This function should be a boolean predicate. */
7920ce38 4968
252b5132 4969static long
7920ce38
NC
4970coff_canonicalize_reloc (bfd * abfd,
4971 sec_ptr section,
4972 arelent ** relptr,
4973 asymbol ** symbols)
252b5132
RH
4974{
4975 arelent *tblptr = section->relocation;
4976 unsigned int count = 0;
4977
252b5132
RH
4978 if (section->flags & SEC_CONSTRUCTOR)
4979 {
ed781d5d
NC
4980 /* This section has relocs made up by us, they are not in the
4981 file, so take them out of their chain and place them into
4982 the data area provided. */
252b5132 4983 arelent_chain *chain = section->constructor_chain;
ed781d5d 4984
252b5132
RH
4985 for (count = 0; count < section->reloc_count; count++)
4986 {
4987 *relptr++ = &chain->relent;
4988 chain = chain->next;
4989 }
252b5132
RH
4990 }
4991 else
4992 {
4993 if (! coff_slurp_reloc_table (abfd, section, symbols))
4994 return -1;
4995
4996 tblptr = section->relocation;
4997
4998 for (; count++ < section->reloc_count;)
4999 *relptr++ = tblptr++;
252b5132
RH
5000 }
5001 *relptr = 0;
5002 return section->reloc_count;
5003}
5004
252b5132
RH
5005#ifndef coff_reloc16_estimate
5006#define coff_reloc16_estimate dummy_reloc16_estimate
5007
252b5132 5008static int
7920ce38
NC
5009dummy_reloc16_estimate (bfd *abfd ATTRIBUTE_UNUSED,
5010 asection *input_section ATTRIBUTE_UNUSED,
5011 arelent *reloc ATTRIBUTE_UNUSED,
5012 unsigned int shrink ATTRIBUTE_UNUSED,
5013 struct bfd_link_info *link_info ATTRIBUTE_UNUSED)
252b5132
RH
5014{
5015 abort ();
00692651 5016 return 0;
252b5132
RH
5017}
5018
5019#endif
5020
5021#ifndef coff_reloc16_extra_cases
5022
5023#define coff_reloc16_extra_cases dummy_reloc16_extra_cases
5024
5025/* This works even if abort is not declared in any header file. */
5026
252b5132 5027static void
7920ce38
NC
5028dummy_reloc16_extra_cases (bfd *abfd ATTRIBUTE_UNUSED,
5029 struct bfd_link_info *link_info ATTRIBUTE_UNUSED,
5030 struct bfd_link_order *link_order ATTRIBUTE_UNUSED,
5031 arelent *reloc ATTRIBUTE_UNUSED,
5032 bfd_byte *data ATTRIBUTE_UNUSED,
5033 unsigned int *src_ptr ATTRIBUTE_UNUSED,
5034 unsigned int *dst_ptr ATTRIBUTE_UNUSED)
252b5132
RH
5035{
5036 abort ();
5037}
5038#endif
5039
e2d34d7d
DJ
5040#ifndef coff_bfd_link_hash_table_free
5041#define coff_bfd_link_hash_table_free _bfd_generic_link_hash_table_free
5042#endif
5043
252b5132
RH
5044/* If coff_relocate_section is defined, we can use the optimized COFF
5045 backend linker. Otherwise we must continue to use the old linker. */
7920ce38 5046
252b5132 5047#ifdef coff_relocate_section
7920ce38 5048
252b5132
RH
5049#ifndef coff_bfd_link_hash_table_create
5050#define coff_bfd_link_hash_table_create _bfd_coff_link_hash_table_create
5051#endif
5052#ifndef coff_bfd_link_add_symbols
5053#define coff_bfd_link_add_symbols _bfd_coff_link_add_symbols
5054#endif
5055#ifndef coff_bfd_final_link
5056#define coff_bfd_final_link _bfd_coff_final_link
5057#endif
7920ce38 5058
252b5132 5059#else /* ! defined (coff_relocate_section) */
7920ce38 5060
252b5132
RH
5061#define coff_relocate_section NULL
5062#ifndef coff_bfd_link_hash_table_create
5063#define coff_bfd_link_hash_table_create _bfd_generic_link_hash_table_create
5064#endif
5065#ifndef coff_bfd_link_add_symbols
5066#define coff_bfd_link_add_symbols _bfd_generic_link_add_symbols
5067#endif
5068#define coff_bfd_final_link _bfd_generic_final_link
7920ce38 5069
252b5132
RH
5070#endif /* ! defined (coff_relocate_section) */
5071
7920ce38 5072#define coff_bfd_link_just_syms _bfd_generic_link_just_syms
252b5132
RH
5073#define coff_bfd_link_split_section _bfd_generic_link_split_section
5074
5075#ifndef coff_start_final_link
5076#define coff_start_final_link NULL
5077#endif
5078
5079#ifndef coff_adjust_symndx
5080#define coff_adjust_symndx NULL
5081#endif
5082
5083#ifndef coff_link_add_one_symbol
5084#define coff_link_add_one_symbol _bfd_generic_link_add_one_symbol
5085#endif
5086
5087#ifndef coff_link_output_has_begun
5088
b34976b6 5089static bfd_boolean
7920ce38
NC
5090coff_link_output_has_begun (bfd * abfd,
5091 struct coff_final_link_info * info ATTRIBUTE_UNUSED)
252b5132
RH
5092{
5093 return abfd->output_has_begun;
5094}
5095#endif
5096
5097#ifndef coff_final_link_postscript
5098
b34976b6 5099static bfd_boolean
7920ce38
NC
5100coff_final_link_postscript (bfd * abfd ATTRIBUTE_UNUSED,
5101 struct coff_final_link_info * pfinfo ATTRIBUTE_UNUSED)
252b5132 5102{
b34976b6 5103 return TRUE;
252b5132
RH
5104}
5105#endif
5106
5107#ifndef coff_SWAP_aux_in
5108#define coff_SWAP_aux_in coff_swap_aux_in
5109#endif
5110#ifndef coff_SWAP_sym_in
5111#define coff_SWAP_sym_in coff_swap_sym_in
5112#endif
5113#ifndef coff_SWAP_lineno_in
5114#define coff_SWAP_lineno_in coff_swap_lineno_in
5115#endif
5116#ifndef coff_SWAP_aux_out
5117#define coff_SWAP_aux_out coff_swap_aux_out
5118#endif
5119#ifndef coff_SWAP_sym_out
5120#define coff_SWAP_sym_out coff_swap_sym_out
5121#endif
5122#ifndef coff_SWAP_lineno_out
5123#define coff_SWAP_lineno_out coff_swap_lineno_out
5124#endif
5125#ifndef coff_SWAP_reloc_out
5126#define coff_SWAP_reloc_out coff_swap_reloc_out
5127#endif
5128#ifndef coff_SWAP_filehdr_out
5129#define coff_SWAP_filehdr_out coff_swap_filehdr_out
5130#endif
5131#ifndef coff_SWAP_aouthdr_out
5132#define coff_SWAP_aouthdr_out coff_swap_aouthdr_out
5133#endif
5134#ifndef coff_SWAP_scnhdr_out
5135#define coff_SWAP_scnhdr_out coff_swap_scnhdr_out
5136#endif
5137#ifndef coff_SWAP_reloc_in
5138#define coff_SWAP_reloc_in coff_swap_reloc_in
5139#endif
5140#ifndef coff_SWAP_filehdr_in
5141#define coff_SWAP_filehdr_in coff_swap_filehdr_in
5142#endif
5143#ifndef coff_SWAP_aouthdr_in
5144#define coff_SWAP_aouthdr_in coff_swap_aouthdr_in
5145#endif
5146#ifndef coff_SWAP_scnhdr_in
5147#define coff_SWAP_scnhdr_in coff_swap_scnhdr_in
5148#endif
5149
cb7a88a4 5150static const bfd_coff_backend_data bfd_coff_std_swap_table ATTRIBUTE_UNUSED =
252b5132
RH
5151{
5152 coff_SWAP_aux_in, coff_SWAP_sym_in, coff_SWAP_lineno_in,
5153 coff_SWAP_aux_out, coff_SWAP_sym_out,
5154 coff_SWAP_lineno_out, coff_SWAP_reloc_out,
5155 coff_SWAP_filehdr_out, coff_SWAP_aouthdr_out,
5156 coff_SWAP_scnhdr_out,
692b7d62 5157 FILHSZ, AOUTSZ, SCNHSZ, SYMESZ, AUXESZ, RELSZ, LINESZ, FILNMLEN,
252b5132 5158#ifdef COFF_LONG_FILENAMES
b34976b6 5159 TRUE,
252b5132 5160#else
b34976b6 5161 FALSE,
252b5132
RH
5162#endif
5163#ifdef COFF_LONG_SECTION_NAMES
b34976b6 5164 TRUE,
252b5132 5165#else
b34976b6 5166 FALSE,
252b5132 5167#endif
a022216b 5168 COFF_DEFAULT_SECTION_ALIGNMENT_POWER,
7f6d05e8 5169#ifdef COFF_FORCE_SYMBOLS_IN_STRINGS
b34976b6 5170 TRUE,
7f6d05e8 5171#else
b34976b6 5172 FALSE,
7f6d05e8
CP
5173#endif
5174#ifdef COFF_DEBUG_STRING_WIDE_PREFIX
5175 4,
5176#else
5177 2,
5178#endif
252b5132
RH
5179 coff_SWAP_filehdr_in, coff_SWAP_aouthdr_in, coff_SWAP_scnhdr_in,
5180 coff_SWAP_reloc_in, coff_bad_format_hook, coff_set_arch_mach_hook,
5181 coff_mkobject_hook, styp_to_sec_flags, coff_set_alignment_hook,
5182 coff_slurp_symbol_table, symname_in_debug_hook, coff_pointerize_aux_hook,
5183 coff_print_aux, coff_reloc16_extra_cases, coff_reloc16_estimate,
5d54c628 5184 coff_classify_symbol, coff_compute_section_file_positions,
252b5132
RH
5185 coff_start_final_link, coff_relocate_section, coff_rtype_to_howto,
5186 coff_adjust_symndx, coff_link_add_one_symbol,
5187 coff_link_output_has_begun, coff_final_link_postscript
5188};
5189
5a5b9651
SS
5190#ifdef TICOFF
5191/* COFF0 differs in file/section header size and relocation entry size. */
7920ce38 5192
5a5b9651
SS
5193static const bfd_coff_backend_data ticoff0_swap_table =
5194{
5195 coff_SWAP_aux_in, coff_SWAP_sym_in, coff_SWAP_lineno_in,
5196 coff_SWAP_aux_out, coff_SWAP_sym_out,
5197 coff_SWAP_lineno_out, coff_SWAP_reloc_out,
5198 coff_SWAP_filehdr_out, coff_SWAP_aouthdr_out,
5199 coff_SWAP_scnhdr_out,
5200 FILHSZ_V0, AOUTSZ, SCNHSZ_V01, SYMESZ, AUXESZ, RELSZ_V0, LINESZ, FILNMLEN,
5201#ifdef COFF_LONG_FILENAMES
5202 TRUE,
5203#else
5204 FALSE,
5205#endif
5206#ifdef COFF_LONG_SECTION_NAMES
5207 TRUE,
5208#else
5209 FALSE,
5210#endif
5211 COFF_DEFAULT_SECTION_ALIGNMENT_POWER,
5212#ifdef COFF_FORCE_SYMBOLS_IN_STRINGS
5213 TRUE,
5214#else
5215 FALSE,
5216#endif
5217#ifdef COFF_DEBUG_STRING_WIDE_PREFIX
5218 4,
5219#else
5220 2,
5221#endif
5222 coff_SWAP_filehdr_in, coff_SWAP_aouthdr_in, coff_SWAP_scnhdr_in,
5223 coff_SWAP_reloc_in, ticoff0_bad_format_hook, coff_set_arch_mach_hook,
5224 coff_mkobject_hook, styp_to_sec_flags, coff_set_alignment_hook,
5225 coff_slurp_symbol_table, symname_in_debug_hook, coff_pointerize_aux_hook,
5226 coff_print_aux, coff_reloc16_extra_cases, coff_reloc16_estimate,
5227 coff_classify_symbol, coff_compute_section_file_positions,
5228 coff_start_final_link, coff_relocate_section, coff_rtype_to_howto,
5229 coff_adjust_symndx, coff_link_add_one_symbol,
5230 coff_link_output_has_begun, coff_final_link_postscript
5231};
5232#endif
5233
5234#ifdef TICOFF
5235/* COFF1 differs in section header size. */
7920ce38 5236
5a5b9651
SS
5237static const bfd_coff_backend_data ticoff1_swap_table =
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,
5244 FILHSZ, AOUTSZ, SCNHSZ_V01, SYMESZ, AUXESZ, RELSZ, LINESZ, FILNMLEN,
5245#ifdef COFF_LONG_FILENAMES
5246 TRUE,
5247#else
5248 FALSE,
5249#endif
5250#ifdef COFF_LONG_SECTION_NAMES
5251 TRUE,
5252#else
5253 FALSE,
5254#endif
5255 COFF_DEFAULT_SECTION_ALIGNMENT_POWER,
5256#ifdef COFF_FORCE_SYMBOLS_IN_STRINGS
5257 TRUE,
5258#else
5259 FALSE,
5260#endif
5261#ifdef COFF_DEBUG_STRING_WIDE_PREFIX
5262 4,
5263#else
5264 2,
5265#endif
5266 coff_SWAP_filehdr_in, coff_SWAP_aouthdr_in, coff_SWAP_scnhdr_in,
5267 coff_SWAP_reloc_in, ticoff1_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,
5271 coff_classify_symbol, coff_compute_section_file_positions,
5272 coff_start_final_link, coff_relocate_section, coff_rtype_to_howto,
5273 coff_adjust_symndx, coff_link_add_one_symbol,
5274 coff_link_output_has_begun, coff_final_link_postscript
5275};
5276#endif
5277
252b5132
RH
5278#ifndef coff_close_and_cleanup
5279#define coff_close_and_cleanup _bfd_generic_close_and_cleanup
5280#endif
5281
5282#ifndef coff_bfd_free_cached_info
5283#define coff_bfd_free_cached_info _bfd_generic_bfd_free_cached_info
5284#endif
5285
5286#ifndef coff_get_section_contents
5287#define coff_get_section_contents _bfd_generic_get_section_contents
5288#endif
5289
5290#ifndef coff_bfd_copy_private_symbol_data
5291#define coff_bfd_copy_private_symbol_data _bfd_generic_bfd_copy_private_symbol_data
5292#endif
5293
80fccad2
BW
5294#ifndef coff_bfd_copy_private_header_data
5295#define coff_bfd_copy_private_header_data _bfd_generic_bfd_copy_private_header_data
5296#endif
5297
252b5132
RH
5298#ifndef coff_bfd_copy_private_section_data
5299#define coff_bfd_copy_private_section_data _bfd_generic_bfd_copy_private_section_data
5300#endif
5301
e60b52c6 5302#ifndef coff_bfd_copy_private_bfd_data
252b5132
RH
5303#define coff_bfd_copy_private_bfd_data _bfd_generic_bfd_copy_private_bfd_data
5304#endif
5305
5306#ifndef coff_bfd_merge_private_bfd_data
5307#define coff_bfd_merge_private_bfd_data _bfd_generic_bfd_merge_private_bfd_data
5308#endif
5309
5310#ifndef coff_bfd_set_private_flags
5311#define coff_bfd_set_private_flags _bfd_generic_bfd_set_private_flags
5312#endif
5313
e60b52c6 5314#ifndef coff_bfd_print_private_bfd_data
252b5132
RH
5315#define coff_bfd_print_private_bfd_data _bfd_generic_bfd_print_private_bfd_data
5316#endif
5317
5318#ifndef coff_bfd_is_local_label_name
5319#define coff_bfd_is_local_label_name _bfd_coff_is_local_label_name
5320#endif
5321
3c9458e9
NC
5322#ifndef coff_bfd_is_target_special_symbol
5323#define coff_bfd_is_target_special_symbol ((bfd_boolean (*) (bfd *, asymbol *)) bfd_false)
5324#endif
5325
252b5132
RH
5326#ifndef coff_read_minisymbols
5327#define coff_read_minisymbols _bfd_generic_read_minisymbols
5328#endif
5329
5330#ifndef coff_minisymbol_to_symbol
5331#define coff_minisymbol_to_symbol _bfd_generic_minisymbol_to_symbol
5332#endif
5333
5334/* The reloc lookup routine must be supplied by each individual COFF
5335 backend. */
5336#ifndef coff_bfd_reloc_type_lookup
5337#define coff_bfd_reloc_type_lookup _bfd_norelocs_bfd_reloc_type_lookup
5338#endif
157090f7
AM
5339#ifndef coff_bfd_reloc_name_lookup
5340#define coff_bfd_reloc_name_lookup _bfd_norelocs_bfd_reloc_name_lookup
5341#endif
252b5132
RH
5342
5343#ifndef coff_bfd_get_relocated_section_contents
5344#define coff_bfd_get_relocated_section_contents \
5345 bfd_generic_get_relocated_section_contents
5346#endif
5347
5348#ifndef coff_bfd_relax_section
5349#define coff_bfd_relax_section bfd_generic_relax_section
5350#endif
5351
5352#ifndef coff_bfd_gc_sections
5353#define coff_bfd_gc_sections bfd_generic_gc_sections
5354#endif
c3c89269 5355
8550eb6e
JJ
5356#ifndef coff_bfd_merge_sections
5357#define coff_bfd_merge_sections bfd_generic_merge_sections
5358#endif
5359
72adc230
AM
5360#ifndef coff_bfd_is_group_section
5361#define coff_bfd_is_group_section bfd_generic_is_group_section
5362#endif
5363
e61463e1
AM
5364#ifndef coff_bfd_discard_group
5365#define coff_bfd_discard_group bfd_generic_discard_group
5366#endif
5367
082b7297
L
5368#ifndef coff_section_already_linked
5369#define coff_section_already_linked \
5370 _bfd_generic_section_already_linked
5371#endif
5372
3fa78519 5373#define CREATE_BIG_COFF_TARGET_VEC(VAR, NAME, EXTRA_O_FLAGS, EXTRA_S_FLAGS, UNDER, ALTERNATIVE, SWAP_TABLE) \
4c117b10
ILT
5374const bfd_target VAR = \
5375{ \
5376 NAME , \
5377 bfd_target_coff_flavour, \
7920ce38
NC
5378 BFD_ENDIAN_BIG, /* Data byte order is big. */ \
5379 BFD_ENDIAN_BIG, /* Header byte order is big. */ \
4c117b10
ILT
5380 /* object flags */ \
5381 (HAS_RELOC | EXEC_P | HAS_LINENO | HAS_DEBUG | \
5382 HAS_SYMS | HAS_LOCALS | WP_TEXT | EXTRA_O_FLAGS), \
5383 /* section flags */ \
5384 (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC | EXTRA_S_FLAGS),\
7920ce38
NC
5385 UNDER, /* Leading symbol underscore. */ \
5386 '/', /* AR_pad_char. */ \
5387 15, /* AR_max_namelen. */ \
4c117b10
ILT
5388 \
5389 /* Data conversion functions. */ \
5390 bfd_getb64, bfd_getb_signed_64, bfd_putb64, \
5391 bfd_getb32, bfd_getb_signed_32, bfd_putb32, \
5392 bfd_getb16, bfd_getb_signed_16, bfd_putb16, \
5393 \
5394 /* Header conversion functions. */ \
5395 bfd_getb64, bfd_getb_signed_64, bfd_putb64, \
5396 bfd_getb32, bfd_getb_signed_32, bfd_putb32, \
5397 bfd_getb16, bfd_getb_signed_16, bfd_putb16, \
5398 \
7920ce38 5399 /* bfd_check_format. */ \
4c117b10
ILT
5400 { _bfd_dummy_target, coff_object_p, bfd_generic_archive_p, \
5401 _bfd_dummy_target }, \
7920ce38 5402 /* bfd_set_format. */ \
4c117b10 5403 { bfd_false, coff_mkobject, _bfd_generic_mkarchive, bfd_false }, \
7920ce38 5404 /* bfd_write_contents. */ \
4c117b10
ILT
5405 { bfd_false, coff_write_object_contents, _bfd_write_archive_contents, \
5406 bfd_false }, \
5407 \
5408 BFD_JUMP_TABLE_GENERIC (coff), \
5409 BFD_JUMP_TABLE_COPY (coff), \
5410 BFD_JUMP_TABLE_CORE (_bfd_nocore), \
5411 BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_coff), \
5412 BFD_JUMP_TABLE_SYMBOLS (coff), \
5413 BFD_JUMP_TABLE_RELOCS (coff), \
5414 BFD_JUMP_TABLE_WRITE (coff), \
5415 BFD_JUMP_TABLE_LINK (coff), \
5416 BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic), \
5417 \
5418 ALTERNATIVE, \
5419 \
3fa78519 5420 SWAP_TABLE \
c3c89269
NC
5421};
5422
3fa78519
SS
5423#define CREATE_BIGHDR_COFF_TARGET_VEC(VAR, NAME, EXTRA_O_FLAGS, EXTRA_S_FLAGS, UNDER, ALTERNATIVE, SWAP_TABLE) \
5424const bfd_target VAR = \
5425{ \
5426 NAME , \
5427 bfd_target_coff_flavour, \
7920ce38
NC
5428 BFD_ENDIAN_LITTLE, /* Data byte order is little. */ \
5429 BFD_ENDIAN_BIG, /* Header byte order is big. */ \
3fa78519
SS
5430 /* object flags */ \
5431 (HAS_RELOC | EXEC_P | HAS_LINENO | HAS_DEBUG | \
5432 HAS_SYMS | HAS_LOCALS | WP_TEXT | EXTRA_O_FLAGS), \
5433 /* section flags */ \
5434 (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC | EXTRA_S_FLAGS),\
7920ce38
NC
5435 UNDER, /* Leading symbol underscore. */ \
5436 '/', /* AR_pad_char. */ \
5437 15, /* AR_max_namelen. */ \
3fa78519
SS
5438 \
5439 /* Data conversion functions. */ \
5440 bfd_getb64, bfd_getb_signed_64, bfd_putb64, \
5441 bfd_getb32, bfd_getb_signed_32, bfd_putb32, \
5442 bfd_getb16, bfd_getb_signed_16, bfd_putb16, \
5443 \
5444 /* Header conversion functions. */ \
5445 bfd_getb64, bfd_getb_signed_64, bfd_putb64, \
5446 bfd_getb32, bfd_getb_signed_32, bfd_putb32, \
5447 bfd_getb16, bfd_getb_signed_16, bfd_putb16, \
5448 \
7920ce38 5449 /* bfd_check_format. */ \
3fa78519
SS
5450 { _bfd_dummy_target, coff_object_p, bfd_generic_archive_p, \
5451 _bfd_dummy_target }, \
7920ce38 5452 /* bfd_set_format. */ \
3fa78519 5453 { bfd_false, coff_mkobject, _bfd_generic_mkarchive, bfd_false }, \
7920ce38 5454 /* bfd_write_contents. */ \
3fa78519
SS
5455 { bfd_false, coff_write_object_contents, _bfd_write_archive_contents, \
5456 bfd_false }, \
5457 \
5458 BFD_JUMP_TABLE_GENERIC (coff), \
5459 BFD_JUMP_TABLE_COPY (coff), \
5460 BFD_JUMP_TABLE_CORE (_bfd_nocore), \
5461 BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_coff), \
5462 BFD_JUMP_TABLE_SYMBOLS (coff), \
5463 BFD_JUMP_TABLE_RELOCS (coff), \
5464 BFD_JUMP_TABLE_WRITE (coff), \
5465 BFD_JUMP_TABLE_LINK (coff), \
5466 BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic), \
5467 \
5468 ALTERNATIVE, \
5469 \
5470 SWAP_TABLE \
5471};
5472
5473#define CREATE_LITTLE_COFF_TARGET_VEC(VAR, NAME, EXTRA_O_FLAGS, EXTRA_S_FLAGS, UNDER, ALTERNATIVE, SWAP_TABLE) \
4c117b10
ILT
5474const bfd_target VAR = \
5475{ \
5476 NAME , \
5477 bfd_target_coff_flavour, \
7920ce38
NC
5478 BFD_ENDIAN_LITTLE, /* Data byte order is little. */ \
5479 BFD_ENDIAN_LITTLE, /* Header byte order is little. */ \
4c117b10
ILT
5480 /* object flags */ \
5481 (HAS_RELOC | EXEC_P | HAS_LINENO | HAS_DEBUG | \
5482 HAS_SYMS | HAS_LOCALS | WP_TEXT | EXTRA_O_FLAGS), \
5483 /* section flags */ \
5484 (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC | EXTRA_S_FLAGS),\
7920ce38
NC
5485 UNDER, /* Leading symbol underscore. */ \
5486 '/', /* AR_pad_char. */ \
5487 15, /* AR_max_namelen. */ \
4c117b10
ILT
5488 \
5489 /* Data conversion functions. */ \
5490 bfd_getl64, bfd_getl_signed_64, bfd_putl64, \
5491 bfd_getl32, bfd_getl_signed_32, bfd_putl32, \
5492 bfd_getl16, bfd_getl_signed_16, bfd_putl16, \
5493 /* Header conversion functions. */ \
5494 bfd_getl64, bfd_getl_signed_64, bfd_putl64, \
5495 bfd_getl32, bfd_getl_signed_32, bfd_putl32, \
5496 bfd_getl16, bfd_getl_signed_16, bfd_putl16, \
7920ce38 5497 /* bfd_check_format. */ \
4c117b10
ILT
5498 { _bfd_dummy_target, coff_object_p, bfd_generic_archive_p, \
5499 _bfd_dummy_target }, \
7920ce38 5500 /* bfd_set_format. */ \
4c117b10 5501 { bfd_false, coff_mkobject, _bfd_generic_mkarchive, bfd_false }, \
7920ce38 5502 /* bfd_write_contents. */ \
4c117b10
ILT
5503 { bfd_false, coff_write_object_contents, _bfd_write_archive_contents, \
5504 bfd_false }, \
5505 \
5506 BFD_JUMP_TABLE_GENERIC (coff), \
5507 BFD_JUMP_TABLE_COPY (coff), \
5508 BFD_JUMP_TABLE_CORE (_bfd_nocore), \
5509 BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_coff), \
5510 BFD_JUMP_TABLE_SYMBOLS (coff), \
5511 BFD_JUMP_TABLE_RELOCS (coff), \
5512 BFD_JUMP_TABLE_WRITE (coff), \
5513 BFD_JUMP_TABLE_LINK (coff), \
5514 BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic), \
5515 \
5516 ALTERNATIVE, \
5517 \
3fa78519 5518 SWAP_TABLE \
c3c89269 5519};
This page took 1.151125 seconds and 4 git commands to generate.