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