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