* elfxx-ia64.c (elfNN_ia64_relax_section): Correct bounds
[binutils.git] / bfd / coffcode.h
blobee50a10993ccbc2d5c94b613a9a5472e48a27ac2
1 /* Support for the generic parts of most COFF variants, for BFD.
2 Copyright 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999,
3 2000, 2001, 2002, 2003
4 Free Software Foundation, Inc.
5 Written by Cygnus Support.
7 This file is part of BFD, the Binary File Descriptor library.
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.
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.
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. */
24 Most of this hacked by Steve Chamberlain,
25 sac@cygnus.com
29 SECTION
30 coff backends
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.
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}.
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}.
52 SUBSECTION
53 Porting to a new version of coff
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.
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.
77 SUBSECTION
78 How the coff backend works
80 SUBSUBSECTION
81 File layout
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.
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.
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}.
101 Some of the Coff targets then also have additional routines in
102 the target source file itself.
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.
113 SUBSUBSECTION
114 Bit twiddling
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}
135 and @code{coff_swap_lineno_in}. @code{GDB} reads the symbol
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.
148 SUBSUBSECTION
149 Symbol reading
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".
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"}).
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.
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.
186 Any linenumbers are read from the coff file too, and attached
187 to the symbols which own the functions the linenumbers belong to.
189 SUBSUBSECTION
190 Symbol writing
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.
198 When the symbols have come from a coff file then all the
199 debugging information is preserved.
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.
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.
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}.
223 o <<coff_mangle_symbols>>
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
228 structured hierarchy required by coff. It changes each pointer
229 to a symbol into the index into the symbol table of the asymbol.
231 o <<coff_write_symbols>>
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.
240 INTERNAL_DEFINITION
241 coff_symbol_type
243 DESCRIPTION
244 The hidden information for an <<asymbol>> is described in a
245 <<combined_entry_type>>:
247 CODE_FRAGMENT
249 .typedef struct coff_ptr_struct
251 . {* Remembers the offset from the first symbol in the file for
252 . this symbol. Generated by coff_renumber_symbols. *}
253 . unsigned int offset;
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;
259 . {* Should the tag field of this symbol be renumbered.
260 . Created by coff_pointerize_aux. *}
261 . unsigned int fix_tag : 1;
263 . {* Should the endidx field of this symbol be renumbered.
264 . Created by coff_pointerize_aux. *}
265 . unsigned int fix_end : 1;
267 . {* Should the x_csect.x_scnlen field be renumbered.
268 . Created by coff_pointerize_aux. *}
269 . unsigned int fix_scnlen : 1;
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;
275 . {* The container for the symbol structure as read and translated
276 . from the file. *}
277 . union
279 . union internal_auxent auxent;
280 . struct internal_syment syment;
281 . } u;
282 .} combined_entry_type;
285 .{* Each canonical asymbol really looks like this: *}
287 .typedef struct coff_symbol_struct
289 . {* The actual symbol which the rest of BFD works with *}
290 . asymbol symbol;
292 . {* A pointer to the hidden information for this symbol *}
293 . combined_entry_type *native;
295 . {* A pointer to the linenumber information for this symbol *}
296 . struct lineno_cache_entry *lineno;
298 . {* Have the line numbers been relocated yet ? *}
299 . bfd_boolean done_lineno;
300 .} coff_symbol_type;
304 #ifdef COFF_WITH_PE
305 #include "peicode.h"
306 #else
307 #include "coffswap.h"
308 #endif
310 #define STRING_SIZE_SIZE (4)
312 static long sec_to_styp_flags
313 PARAMS ((const char *, flagword));
314 static bfd_boolean styp_to_sec_flags
315 PARAMS ((bfd *, PTR, const char *, asection *, flagword *));
316 static bfd_boolean coff_bad_format_hook
317 PARAMS ((bfd *, PTR));
318 static void coff_set_custom_section_alignment
319 PARAMS ((bfd *, asection *, const struct coff_section_alignment_entry *,
320 const unsigned int));
321 static bfd_boolean coff_new_section_hook
322 PARAMS ((bfd *, asection *));
323 static bfd_boolean coff_set_arch_mach_hook
324 PARAMS ((bfd *, PTR));
325 static bfd_boolean coff_write_relocs
326 PARAMS ((bfd *, int));
327 static bfd_boolean coff_set_flags
328 PARAMS ((bfd *, unsigned int *, unsigned short *));
329 static bfd_boolean coff_set_arch_mach
330 PARAMS ((bfd *, enum bfd_architecture, unsigned long)) ATTRIBUTE_UNUSED;
331 static bfd_boolean coff_compute_section_file_positions
332 PARAMS ((bfd *));
333 static bfd_boolean coff_write_object_contents
334 PARAMS ((bfd *)) ATTRIBUTE_UNUSED;
335 static bfd_boolean coff_set_section_contents
336 PARAMS ((bfd *, asection *, PTR, file_ptr, bfd_size_type));
337 static PTR buy_and_read
338 PARAMS ((bfd *, file_ptr, bfd_size_type));
339 static bfd_boolean coff_slurp_line_table
340 PARAMS ((bfd *, asection *));
341 static bfd_boolean coff_slurp_symbol_table
342 PARAMS ((bfd *));
343 static enum coff_symbol_classification coff_classify_symbol
344 PARAMS ((bfd *, struct internal_syment *));
345 static bfd_boolean coff_slurp_reloc_table
346 PARAMS ((bfd *, asection *, asymbol **));
347 static long coff_canonicalize_reloc
348 PARAMS ((bfd *, asection *, arelent **, asymbol **));
349 #ifndef coff_mkobject_hook
350 static PTR coff_mkobject_hook
351 PARAMS ((bfd *, PTR, PTR));
352 #endif
353 #ifdef COFF_WITH_PE
354 static flagword handle_COMDAT
355 PARAMS ((bfd *, flagword, PTR, const char *, asection *));
356 #endif
357 #ifdef COFF_IMAGE_WITH_PE
358 static bfd_boolean coff_read_word
359 PARAMS ((bfd *, unsigned int *));
360 static unsigned int coff_compute_checksum
361 PARAMS ((bfd *));
362 static bfd_boolean coff_apply_checksum
363 PARAMS ((bfd *));
364 #endif
366 /* void warning(); */
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(). */
373 #ifndef COFF_WITH_PE
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
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
388 static long
389 sec_to_styp_flags (sec_name, sec_flags)
390 const char *sec_name;
391 flagword sec_flags;
393 long styp_flags = 0;
395 if (!strcmp (sec_name, _TEXT))
397 styp_flags = STYP_TEXT;
399 else if (!strcmp (sec_name, _DATA))
401 styp_flags = STYP_DATA;
403 else if (!strcmp (sec_name, _BSS))
405 styp_flags = STYP_BSS;
406 #ifdef _COMMENT
408 else if (!strcmp (sec_name, _COMMENT))
410 styp_flags = STYP_INFO;
411 #endif /* _COMMENT */
412 #ifdef _LIB
414 else if (!strcmp (sec_name, _LIB))
416 styp_flags = STYP_LIB;
417 #endif /* _LIB */
418 #ifdef _LIT
420 else if (!strcmp (sec_name, _LIT))
422 styp_flags = STYP_LIT;
423 #endif /* _LIT */
425 else if (!strncmp (sec_name, ".debug", 6))
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;
433 else if (!strncmp (sec_name, ".stab", 5))
435 styp_flags = STYP_DEBUG_INFO;
437 #ifdef COFF_LONG_SECTION_NAMES
438 else if (!strncmp (sec_name, ".gnu.linkonce.wi.", 17))
440 styp_flags = STYP_DEBUG_INFO;
442 #endif
443 #ifdef RS6000COFF_C
444 else if (!strcmp (sec_name, _PAD))
446 styp_flags = STYP_PAD;
448 else if (!strcmp (sec_name, _LOADER))
450 styp_flags = STYP_LOADER;
452 else if (!strcmp (sec_name, _EXCEPT))
454 styp_flags = STYP_EXCEPT;
456 else if (!strcmp (sec_name, _TYPCHK))
458 styp_flags = STYP_TYPCHK;
460 #endif
461 /* Try and figure out what it should be */
462 else if (sec_flags & SEC_CODE)
464 styp_flags = STYP_TEXT;
466 else if (sec_flags & SEC_DATA)
468 styp_flags = STYP_DATA;
470 else if (sec_flags & SEC_READONLY)
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 */
478 else if (sec_flags & SEC_LOAD)
480 styp_flags = STYP_TEXT;
482 else if (sec_flags & SEC_ALLOC)
484 styp_flags = STYP_BSS;
487 #ifdef STYP_CLINK
488 if (sec_flags & SEC_CLINK)
489 styp_flags |= STYP_CLINK;
490 #endif
492 #ifdef STYP_BLOCK
493 if (sec_flags & SEC_BLOCK)
494 styp_flags |= STYP_BLOCK;
495 #endif
497 #ifdef STYP_NOLOAD
498 if ((sec_flags & (SEC_NEVER_LOAD | SEC_COFF_SHARED_LIBRARY)) != 0)
499 styp_flags |= STYP_NOLOAD;
500 #endif
502 return styp_flags;
505 #else /* COFF_WITH_PE */
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. */
513 static long
514 sec_to_styp_flags (sec_name, sec_flags)
515 const char *sec_name ATTRIBUTE_UNUSED;
516 flagword sec_flags;
518 long styp_flags = 0;
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. */
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 */
538 /* skip constRUCTOR */
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)
545 styp_flags |= IMAGE_SCN_LNK_COMDAT;
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 */
554 if (sec_flags & SEC_LINK_ONCE)
555 styp_flags |= IMAGE_SCN_LNK_COMDAT;
556 /* skip LINK_DUPLICATES */
557 /* skip LINKER_CREATED */
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
561 are retained in pei_section_data(abfd, section)->pe_flags. */
563 styp_flags |= IMAGE_SCN_MEM_READ; /* Always readable. */
564 if ((sec_flags & SEC_READONLY) == 0)
565 styp_flags |= IMAGE_SCN_MEM_WRITE; /* Invert READONLY for write. */
566 if (sec_flags & SEC_CODE)
567 styp_flags |= IMAGE_SCN_MEM_EXECUTE; /* CODE->EXECUTE. */
568 if (sec_flags & SEC_SHARED)
569 styp_flags |= IMAGE_SCN_MEM_SHARED; /* Shared remains meaningful. */
571 return styp_flags;
574 #endif /* COFF_WITH_PE */
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(). */
581 #ifndef COFF_WITH_PE
583 static bfd_boolean
584 styp_to_sec_flags (abfd, hdr, name, section, flags_ptr)
585 bfd *abfd ATTRIBUTE_UNUSED;
586 PTR hdr;
587 const char *name;
588 asection *section ATTRIBUTE_UNUSED;
589 flagword *flags_ptr;
591 struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
592 long styp_flags = internal_s->s_flags;
593 flagword sec_flags = 0;
595 #ifdef STYP_BLOCK
596 if (styp_flags & STYP_BLOCK)
597 sec_flags |= SEC_BLOCK;
598 #endif
600 #ifdef STYP_CLINK
601 if (styp_flags & STYP_CLINK)
602 sec_flags |= SEC_CLINK;
603 #endif
605 #ifdef STYP_NOLOAD
606 if (styp_flags & STYP_NOLOAD)
607 sec_flags |= SEC_NEVER_LOAD;
608 #endif /* STYP_NOLOAD */
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)
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;
619 else if (styp_flags & STYP_DATA)
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;
626 else if (styp_flags & STYP_BSS)
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;
635 else if (styp_flags & STYP_INFO)
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
647 else if (styp_flags & STYP_PAD)
648 sec_flags = 0;
649 else if (strcmp (name, _TEXT) == 0)
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;
656 else if (strcmp (name, _DATA) == 0)
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;
663 else if (strcmp (name, _BSS) == 0)
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;
672 else if (strncmp (name, ".debug", 6) == 0
673 #ifdef _COMMENT
674 || strcmp (name, _COMMENT) == 0
675 #endif
676 #ifdef COFF_LONG_SECTION_NAMES
677 || strncmp (name, ".gnu.linkonce.wi.", 17) == 0
678 #endif
679 || strncmp (name, ".stab", 5) == 0)
681 #ifdef COFF_PAGE_SIZE
682 sec_flags |= SEC_DEBUGGING;
683 #endif
685 #ifdef _LIB
686 else if (strcmp (name, _LIB) == 0)
688 #endif
689 #ifdef _LIT
690 else if (strcmp (name, _LIT) == 0)
691 sec_flags = SEC_LOAD | SEC_ALLOC | SEC_READONLY;
692 #endif
693 else
694 sec_flags |= SEC_ALLOC | SEC_LOAD;
696 #ifdef STYP_LIT /* A29k readonly text/data section type. */
697 if ((styp_flags & STYP_LIT) == STYP_LIT)
698 sec_flags = (SEC_LOAD | SEC_ALLOC | SEC_READONLY);
699 #endif /* STYP_LIT */
701 #ifdef STYP_OTHER_LOAD /* Other loaded sections. */
702 if (styp_flags & STYP_OTHER_LOAD)
703 sec_flags = (SEC_LOAD | SEC_ALLOC);
704 #endif /* STYP_SDATA */
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
717 if (flags_ptr == NULL)
718 return FALSE;
720 * flags_ptr = sec_flags;
721 return TRUE;
724 #else /* COFF_WITH_PE */
726 static flagword
727 handle_COMDAT (abfd, sec_flags, hdr, name, section)
728 bfd * abfd;
729 flagword sec_flags;
730 PTR hdr;
731 const char *name;
732 asection *section;
734 struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
735 bfd_byte *esymstart, *esym, *esymend;
736 int seen_state = 0;
737 char *target_name = NULL;
739 sec_flags |= SEC_LINK_ONCE;
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. */
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 */
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. */
758 if (! _bfd_coff_get_external_symbols (abfd))
759 return sec_flags;
761 esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
762 esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
764 while (esym < esymend)
766 struct internal_syment isym;
767 char buf[SYMNMLEN + 1];
768 const char *symname;
770 bfd_coff_swap_sym_in (abfd, (PTR) esym, (PTR) &isym);
772 if (sizeof (internal_s->s_name) > SYMNMLEN)
774 /* This case implies that the matching
775 symbol name will be in the string table. */
776 abort ();
779 if (isym.n_scnum == section->target_index)
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.
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.
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:
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. */
805 /* All 3 branches use this. */
806 symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
808 if (symname == NULL)
809 abort ();
811 switch (seen_state)
813 case 0:
815 /* The first time we've seen the symbol. */
816 union internal_auxent aux;
818 seen_state = 1;
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.)
832 Here, we think we've found the first one,
833 but there's some checking we can do to be
834 sure. */
836 if (! (isym.n_sclass == C_STAT
837 && isym.n_type == T_NULL
838 && isym.n_value == 0))
839 abort ();
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. */
846 if (strcmp (name, symname) != 0)
847 abort ();
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);
854 target_name = strchr (name, '$');
855 if (target_name != NULL)
857 /* Gas mode. */
858 seen_state = 2;
859 /* Skip the `$'. */
860 target_name += 1;
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. */
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. */
879 switch (aux.x_scn.x_comdat)
881 case IMAGE_COMDAT_SELECT_NODUPLICATES:
882 #ifdef STRICT_PE_FORMAT
883 sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
884 #else
885 sec_flags &= ~SEC_LINK_ONCE;
886 #endif
887 break;
889 case IMAGE_COMDAT_SELECT_ANY:
890 sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
891 break;
893 case IMAGE_COMDAT_SELECT_SAME_SIZE:
894 sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
895 break;
897 case IMAGE_COMDAT_SELECT_EXACT_MATCH:
898 /* Not yet fully implemented ??? */
899 sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
900 break;
902 /* debug$S gets this case; other
903 implications ??? */
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:
910 #ifdef STRICT_PE_FORMAT
911 /* FIXME: This is not currently implemented. */
912 sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
913 #else
914 sec_flags &= ~SEC_LINK_ONCE;
915 #endif
916 break;
918 default: /* 0 means "no symbol" */
919 /* debug$F gets this case; other
920 implications ??? */
921 sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
922 break;
925 break;
927 case 2:
928 /* Gas mode: the first matching on partial name. */
930 #ifndef TARGET_UNDERSCORE
931 #define TARGET_UNDERSCORE 0
932 #endif
933 /* Is this the name we're looking for ? */
934 if (strcmp (target_name,
935 symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
937 /* Not the name we're looking for */
938 esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd);
939 continue;
941 /* Fall through. */
942 case 1:
943 /* MSVC mode: the lexically second symbol (or
944 drop through from the above). */
946 char *newname;
947 bfd_size_type amt;
949 /* This must the second symbol with the
950 section #. It is the actual symbol name.
951 Intel puts the two adjacent, but Alpha (at
952 least) spreads them out. */
954 amt = sizeof (struct bfd_comdat_info);
955 section->comdat = bfd_alloc (abfd, amt);
956 if (section->comdat == NULL)
957 abort ();
959 section->comdat->symbol =
960 (esym - esymstart) / bfd_coff_symesz (abfd);
962 amt = strlen (symname) + 1;
963 newname = bfd_alloc (abfd, amt);
964 if (newname == NULL)
965 abort ();
967 strcpy (newname, symname);
968 section->comdat->name = newname;
971 goto breakloop;
975 esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd);
978 breakloop:
979 return sec_flags;
983 /* The PE version; see above for the general comments.
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? */
992 static bfd_boolean
993 styp_to_sec_flags (abfd, hdr, name, section, flags_ptr)
994 bfd *abfd;
995 PTR hdr;
996 const char *name;
997 asection *section;
998 flagword *flags_ptr;
1000 struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1001 long styp_flags = internal_s->s_flags;
1002 flagword sec_flags;
1003 bfd_boolean result = TRUE;
1005 /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified. */
1006 sec_flags = SEC_READONLY;
1008 /* Process each flag bit in styp_flags in turn. */
1009 while (styp_flags)
1011 long flag = styp_flags & - styp_flags;
1012 char * unhandled = NULL;
1014 styp_flags &= ~ flag;
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. */
1020 switch (flag)
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;
1038 #endif
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. */
1095 break;
1098 /* If the section flag was not handled, report it here. */
1099 if (unhandled != NULL)
1101 (*_bfd_error_handler)
1102 (_("%s (%s): Section flag %s (0x%x) ignored"),
1103 bfd_archive_filename (abfd), name, unhandled, flag);
1104 result = FALSE;
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
1119 if (flags_ptr)
1120 * flags_ptr = sec_flags;
1122 return result;
1125 #endif /* COFF_WITH_PE */
1127 #define get_index(symbol) ((symbol)->udata.i)
1130 INTERNAL_DEFINITION
1131 bfd_coff_backend_data
1133 CODE_FRAGMENT
1135 .{* COFF symbol classifications. *}
1137 .enum coff_symbol_classification
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
1151 Special entry points for gdb to swap in coff symbol table parts:
1152 .typedef struct
1154 . void (*_bfd_coff_swap_aux_in)
1155 . PARAMS ((bfd *, PTR, int, int, int, int, PTR));
1157 . void (*_bfd_coff_swap_sym_in)
1158 . PARAMS ((bfd *, PTR, PTR));
1160 . void (*_bfd_coff_swap_lineno_in)
1161 . PARAMS ((bfd *, PTR, PTR));
1163 . unsigned int (*_bfd_coff_swap_aux_out)
1164 . PARAMS ((bfd *, PTR, int, int, int, int, PTR));
1166 . unsigned int (*_bfd_coff_swap_sym_out)
1167 . PARAMS ((bfd *, PTR, PTR));
1169 . unsigned int (*_bfd_coff_swap_lineno_out)
1170 . PARAMS ((bfd *, PTR, PTR));
1172 . unsigned int (*_bfd_coff_swap_reloc_out)
1173 . PARAMS ((bfd *, PTR, PTR));
1175 . unsigned int (*_bfd_coff_swap_filehdr_out)
1176 . PARAMS ((bfd *, PTR, PTR));
1178 . unsigned int (*_bfd_coff_swap_aouthdr_out)
1179 . PARAMS ((bfd *, PTR, PTR));
1181 . unsigned int (*_bfd_coff_swap_scnhdr_out)
1182 . PARAMS ((bfd *, PTR, PTR));
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;
1192 . bfd_boolean _bfd_coff_long_filenames;
1193 . bfd_boolean _bfd_coff_long_section_names;
1194 . unsigned int _bfd_coff_default_section_alignment_power;
1195 . bfd_boolean _bfd_coff_force_symnames_in_strings;
1196 . unsigned int _bfd_coff_debug_string_prefix_length;
1198 . void (*_bfd_coff_swap_filehdr_in)
1199 . PARAMS ((bfd *, PTR, PTR));
1201 . void (*_bfd_coff_swap_aouthdr_in)
1202 . PARAMS ((bfd *, PTR, PTR));
1204 . void (*_bfd_coff_swap_scnhdr_in)
1205 . PARAMS ((bfd *, PTR, PTR));
1207 . void (*_bfd_coff_swap_reloc_in)
1208 . PARAMS ((bfd *abfd, PTR, PTR));
1210 . bfd_boolean (*_bfd_coff_bad_format_hook)
1211 . PARAMS ((bfd *, PTR));
1213 . bfd_boolean (*_bfd_coff_set_arch_mach_hook)
1214 . PARAMS ((bfd *, PTR));
1216 . PTR (*_bfd_coff_mkobject_hook)
1217 . PARAMS ((bfd *, PTR, PTR));
1219 . bfd_boolean (*_bfd_styp_to_sec_flags_hook)
1220 . PARAMS ((bfd *, PTR, const char *, asection *, flagword *));
1222 . void (*_bfd_set_alignment_hook)
1223 . PARAMS ((bfd *, asection *, PTR));
1225 . bfd_boolean (*_bfd_coff_slurp_symbol_table)
1226 . PARAMS ((bfd *));
1228 . bfd_boolean (*_bfd_coff_symname_in_debug)
1229 . PARAMS ((bfd *, struct internal_syment *));
1231 . bfd_boolean (*_bfd_coff_pointerize_aux_hook)
1232 . PARAMS ((bfd *, combined_entry_type *, combined_entry_type *,
1233 . unsigned int, combined_entry_type *));
1235 . bfd_boolean (*_bfd_coff_print_aux)
1236 . PARAMS ((bfd *, FILE *, combined_entry_type *, combined_entry_type *,
1237 . combined_entry_type *, unsigned int));
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 *));
1243 . int (*_bfd_coff_reloc16_estimate)
1244 . PARAMS ((bfd *, asection *, arelent *, unsigned int,
1245 . struct bfd_link_info *));
1247 . enum coff_symbol_classification (*_bfd_coff_classify_symbol)
1248 . PARAMS ((bfd *, struct internal_syment *));
1250 . bfd_boolean (*_bfd_coff_compute_section_file_positions)
1251 . PARAMS ((bfd *));
1253 . bfd_boolean (*_bfd_coff_start_final_link)
1254 . PARAMS ((bfd *, struct bfd_link_info *));
1256 . bfd_boolean (*_bfd_coff_relocate_section)
1257 . PARAMS ((bfd *, struct bfd_link_info *, bfd *, asection *, bfd_byte *,
1258 . struct internal_reloc *, struct internal_syment *, asection **));
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 *));
1265 . bfd_boolean (*_bfd_coff_adjust_symndx)
1266 . PARAMS ((bfd *, struct bfd_link_info *, bfd *, asection *,
1267 . struct internal_reloc *, bfd_boolean *));
1269 . bfd_boolean (*_bfd_coff_link_add_one_symbol)
1270 . PARAMS ((struct bfd_link_info *, bfd *, const char *, flagword,
1271 . asection *, bfd_vma, const char *, bfd_boolean, bfd_boolean,
1272 . struct bfd_link_hash_entry **));
1274 . bfd_boolean (*_bfd_coff_link_output_has_begun)
1275 . PARAMS ((bfd *, struct coff_final_link_info *));
1277 . bfd_boolean (*_bfd_coff_final_link_postscript)
1278 . PARAMS ((bfd *, struct coff_final_link_info *));
1280 .} bfd_coff_backend_data;
1282 .#define coff_backend_info(abfd) \
1283 . ((bfd_coff_backend_data *) (abfd)->xvec->backend_data)
1285 .#define bfd_coff_swap_aux_in(a,e,t,c,ind,num,i) \
1286 . ((coff_backend_info (a)->_bfd_coff_swap_aux_in) (a,e,t,c,ind,num,i))
1288 .#define bfd_coff_swap_sym_in(a,e,i) \
1289 . ((coff_backend_info (a)->_bfd_coff_swap_sym_in) (a,e,i))
1291 .#define bfd_coff_swap_lineno_in(a,e,i) \
1292 . ((coff_backend_info ( a)->_bfd_coff_swap_lineno_in) (a,e,i))
1294 .#define bfd_coff_swap_reloc_out(abfd, i, o) \
1295 . ((coff_backend_info (abfd)->_bfd_coff_swap_reloc_out) (abfd, i, o))
1297 .#define bfd_coff_swap_lineno_out(abfd, i, o) \
1298 . ((coff_backend_info (abfd)->_bfd_coff_swap_lineno_out) (abfd, i, o))
1300 .#define bfd_coff_swap_aux_out(a,i,t,c,ind,num,o) \
1301 . ((coff_backend_info (a)->_bfd_coff_swap_aux_out) (a,i,t,c,ind,num,o))
1303 .#define bfd_coff_swap_sym_out(abfd, i,o) \
1304 . ((coff_backend_info (abfd)->_bfd_coff_swap_sym_out) (abfd, i, o))
1306 .#define bfd_coff_swap_scnhdr_out(abfd, i,o) \
1307 . ((coff_backend_info (abfd)->_bfd_coff_swap_scnhdr_out) (abfd, i, o))
1309 .#define bfd_coff_swap_filehdr_out(abfd, i,o) \
1310 . ((coff_backend_info (abfd)->_bfd_coff_swap_filehdr_out) (abfd, i, o))
1312 .#define bfd_coff_swap_aouthdr_out(abfd, i,o) \
1313 . ((coff_backend_info (abfd)->_bfd_coff_swap_aouthdr_out) (abfd, i, o))
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)
1322 .#define bfd_coff_filnmlen(abfd) (coff_backend_info (abfd)->_bfd_filnmlen)
1323 .#define bfd_coff_long_filenames(abfd) \
1324 . (coff_backend_info (abfd)->_bfd_coff_long_filenames)
1325 .#define bfd_coff_long_section_names(abfd) \
1326 . (coff_backend_info (abfd)->_bfd_coff_long_section_names)
1327 .#define bfd_coff_default_section_alignment_power(abfd) \
1328 . (coff_backend_info (abfd)->_bfd_coff_default_section_alignment_power)
1329 .#define bfd_coff_swap_filehdr_in(abfd, i,o) \
1330 . ((coff_backend_info (abfd)->_bfd_coff_swap_filehdr_in) (abfd, i, o))
1332 .#define bfd_coff_swap_aouthdr_in(abfd, i,o) \
1333 . ((coff_backend_info (abfd)->_bfd_coff_swap_aouthdr_in) (abfd, i, o))
1335 .#define bfd_coff_swap_scnhdr_in(abfd, i,o) \
1336 . ((coff_backend_info (abfd)->_bfd_coff_swap_scnhdr_in) (abfd, i, o))
1338 .#define bfd_coff_swap_reloc_in(abfd, i, o) \
1339 . ((coff_backend_info (abfd)->_bfd_coff_swap_reloc_in) (abfd, i, o))
1341 .#define bfd_coff_bad_format_hook(abfd, filehdr) \
1342 . ((coff_backend_info (abfd)->_bfd_coff_bad_format_hook) (abfd, filehdr))
1344 .#define bfd_coff_set_arch_mach_hook(abfd, filehdr)\
1345 . ((coff_backend_info (abfd)->_bfd_coff_set_arch_mach_hook) (abfd, filehdr))
1346 .#define bfd_coff_mkobject_hook(abfd, filehdr, aouthdr)\
1347 . ((coff_backend_info (abfd)->_bfd_coff_mkobject_hook)\
1348 . (abfd, filehdr, aouthdr))
1350 .#define bfd_coff_styp_to_sec_flags_hook(abfd, scnhdr, name, section, flags_ptr)\
1351 . ((coff_backend_info (abfd)->_bfd_styp_to_sec_flags_hook)\
1352 . (abfd, scnhdr, name, section, flags_ptr))
1354 .#define bfd_coff_set_alignment_hook(abfd, sec, scnhdr)\
1355 . ((coff_backend_info (abfd)->_bfd_set_alignment_hook) (abfd, sec, scnhdr))
1357 .#define bfd_coff_slurp_symbol_table(abfd)\
1358 . ((coff_backend_info (abfd)->_bfd_coff_slurp_symbol_table) (abfd))
1360 .#define bfd_coff_symname_in_debug(abfd, sym)\
1361 . ((coff_backend_info (abfd)->_bfd_coff_symname_in_debug) (abfd, sym))
1363 .#define bfd_coff_force_symnames_in_strings(abfd)\
1364 . (coff_backend_info (abfd)->_bfd_coff_force_symnames_in_strings)
1366 .#define bfd_coff_debug_string_prefix_length(abfd)\
1367 . (coff_backend_info (abfd)->_bfd_coff_debug_string_prefix_length)
1369 .#define bfd_coff_print_aux(abfd, file, base, symbol, aux, indaux)\
1370 . ((coff_backend_info (abfd)->_bfd_coff_print_aux)\
1371 . (abfd, file, base, symbol, aux, indaux))
1373 .#define bfd_coff_reloc16_extra_cases(abfd, link_info, link_order,\
1374 . reloc, data, src_ptr, dst_ptr)\
1375 . ((coff_backend_info (abfd)->_bfd_coff_reloc16_extra_cases)\
1376 . (abfd, link_info, link_order, reloc, data, src_ptr, dst_ptr))
1378 .#define bfd_coff_reloc16_estimate(abfd, section, reloc, shrink, link_info)\
1379 . ((coff_backend_info (abfd)->_bfd_coff_reloc16_estimate)\
1380 . (abfd, section, reloc, shrink, link_info))
1382 .#define bfd_coff_classify_symbol(abfd, sym)\
1383 . ((coff_backend_info (abfd)->_bfd_coff_classify_symbol)\
1384 . (abfd, sym))
1386 .#define bfd_coff_compute_section_file_positions(abfd)\
1387 . ((coff_backend_info (abfd)->_bfd_coff_compute_section_file_positions)\
1388 . (abfd))
1390 .#define bfd_coff_start_final_link(obfd, info)\
1391 . ((coff_backend_info (obfd)->_bfd_coff_start_final_link)\
1392 . (obfd, info))
1393 .#define bfd_coff_relocate_section(obfd,info,ibfd,o,con,rel,isyms,secs)\
1394 . ((coff_backend_info (ibfd)->_bfd_coff_relocate_section)\
1395 . (obfd, info, ibfd, o, con, rel, isyms, secs))
1396 .#define bfd_coff_rtype_to_howto(abfd, sec, rel, h, sym, addendp)\
1397 . ((coff_backend_info (abfd)->_bfd_coff_rtype_to_howto)\
1398 . (abfd, sec, rel, h, sym, addendp))
1399 .#define bfd_coff_adjust_symndx(obfd, info, ibfd, sec, rel, adjustedp)\
1400 . ((coff_backend_info (abfd)->_bfd_coff_adjust_symndx)\
1401 . (obfd, info, ibfd, sec, rel, adjustedp))
1402 .#define bfd_coff_link_add_one_symbol(info, abfd, name, flags, section,\
1403 . value, string, cp, coll, hashp)\
1404 . ((coff_backend_info (abfd)->_bfd_coff_link_add_one_symbol)\
1405 . (info, abfd, name, flags, section, value, string, cp, coll, hashp))
1407 .#define bfd_coff_link_output_has_begun(a,p) \
1408 . ((coff_backend_info (a)->_bfd_coff_link_output_has_begun) (a,p))
1409 .#define bfd_coff_final_link_postscript(a,p) \
1410 . ((coff_backend_info (a)->_bfd_coff_final_link_postscript) (a,p))
1414 /* See whether the magic number matches. */
1416 static bfd_boolean
1417 coff_bad_format_hook (abfd, filehdr)
1418 bfd * abfd ATTRIBUTE_UNUSED;
1419 PTR filehdr;
1421 struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1423 if (BADMAG (*internal_f))
1424 return FALSE;
1426 /* If the optional header is NULL or not the correct size then
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.
1431 But the mips keeps extra stuff in it's opthdr, so dont check
1432 when doing that. */
1434 #if defined(M88) || defined(I960)
1435 if (internal_f->f_opthdr != 0 && bfd_coff_aoutsz (abfd) != internal_f->f_opthdr)
1436 return FALSE;
1437 #endif
1439 return TRUE;
1442 /* Check whether this section uses an alignment other than the
1443 default. */
1445 static void
1446 coff_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;
1452 const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1453 unsigned int i;
1455 for (i = 0; i < table_size; ++i)
1457 const char *secname = bfd_get_section_name (abfd, section);
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;
1465 if (i >= table_size)
1466 return;
1468 if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1469 && default_alignment < alignment_table[i].default_alignment_min)
1470 return;
1472 if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1473 #if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1474 && default_alignment > alignment_table[i].default_alignment_max
1475 #endif
1477 return;
1479 section->alignment_power = alignment_table[i].alignment_power;
1482 /* Custom section alignment records. */
1484 static const struct coff_section_alignment_entry
1485 coff_section_alignment_table[] =
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 }
1503 static const unsigned int coff_section_alignment_table_size =
1504 sizeof coff_section_alignment_table / sizeof coff_section_alignment_table[0];
1506 /* Initialize a section structure with information peculiar to this
1507 particular implementation of COFF. */
1509 static bfd_boolean
1510 coff_new_section_hook (abfd, section)
1511 bfd * abfd;
1512 asection * section;
1514 combined_entry_type *native;
1515 bfd_size_type amt;
1517 section->alignment_power = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1519 #ifdef RS6000COFF_C
1520 if (bfd_xcoff_text_align_power (abfd) != 0
1521 && strcmp (bfd_get_section_name (abfd, section), ".text") == 0)
1522 section->alignment_power = bfd_xcoff_text_align_power (abfd);
1523 if (bfd_xcoff_data_align_power (abfd) != 0
1524 && strcmp (bfd_get_section_name (abfd, section), ".data") == 0)
1525 section->alignment_power = bfd_xcoff_data_align_power (abfd);
1526 #endif
1528 /* Allocate aux records for section symbols, to store size and
1529 related info.
1531 @@ The 10 is a guess at a plausible maximum number of aux entries
1532 (but shouldn't be a constant). */
1533 amt = sizeof (combined_entry_type) * 10;
1534 native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1535 if (native == NULL)
1536 return FALSE;
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. */
1544 native->u.syment.n_type = T_NULL;
1545 native->u.syment.n_sclass = C_STAT;
1547 coffsymbol (section->symbol)->native = native;
1549 coff_set_custom_section_alignment (abfd, section,
1550 coff_section_alignment_table,
1551 coff_section_alignment_table_size);
1553 return TRUE;
1556 #ifdef COFF_ALIGN_IN_SECTION_HEADER
1558 /* Set the alignment of a BFD section. */
1560 static void coff_set_alignment_hook PARAMS ((bfd *, asection *, PTR));
1562 static void
1563 coff_set_alignment_hook (abfd, section, scnhdr)
1564 bfd * abfd ATTRIBUTE_UNUSED;
1565 asection * section;
1566 PTR scnhdr;
1568 struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1569 unsigned int i;
1571 #ifdef I960
1572 /* Extract ALIGN from 2**ALIGN stored in section header. */
1573 for (i = 0; i < 32; i++)
1574 if ((1 << i) >= hdr->s_align)
1575 break;
1576 #endif
1577 #ifdef TIC80COFF
1578 /* TI tools puts the alignment power in bits 8-11. */
1579 i = (hdr->s_flags >> 8) & 0xF ;
1580 #endif
1581 #ifdef COFF_DECODE_ALIGNMENT
1582 i = COFF_DECODE_ALIGNMENT(hdr->s_flags);
1583 #endif
1584 section->alignment_power = i;
1586 #ifdef coff_set_section_load_page
1587 coff_set_section_load_page (section, hdr->s_page);
1588 #endif
1591 #else /* ! COFF_ALIGN_IN_SECTION_HEADER */
1592 #ifdef COFF_WITH_PE
1594 /* A couple of macros to help setting the alignment power field. */
1595 #define ALIGN_SET(field,x,y) \
1596 if (((field) & IMAGE_SCN_ALIGN_64BYTES) == x )\
1598 section->alignment_power = y;\
1601 #define ELIFALIGN_SET(field,x,y) \
1602 else if (( (field) & IMAGE_SCN_ALIGN_64BYTES) == x ) \
1604 section->alignment_power = y;\
1607 static void coff_set_alignment_hook PARAMS ((bfd *, asection *, PTR));
1609 static void
1610 coff_set_alignment_hook (abfd, section, scnhdr)
1611 bfd * abfd ATTRIBUTE_UNUSED;
1612 asection * section;
1613 PTR scnhdr;
1615 struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1616 bfd_size_type amt;
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)
1626 /* In a PE image file, the s_paddr field holds the virtual size of a
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)
1632 amt = sizeof (struct coff_section_tdata);
1633 section->used_by_bfd = (PTR) bfd_zalloc (abfd, amt);
1634 if (section->used_by_bfd == NULL)
1636 /* FIXME: Return error. */
1637 abort ();
1640 if (pei_section_data (abfd, section) == NULL)
1642 amt = sizeof (struct pei_section_tdata);
1643 coff_section_data (abfd, section)->tdata = (PTR) bfd_zalloc (abfd, amt);
1644 if (coff_section_data (abfd, section)->tdata == NULL)
1646 /* FIXME: Return error. */
1647 abort ();
1650 pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1651 pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1653 section->lma = hdr->s_vaddr;
1655 /* Check for extended relocs. */
1656 if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1658 struct external_reloc dst;
1659 struct internal_reloc n;
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)
1663 != bfd_coff_relsz (abfd))
1664 return;
1666 coff_swap_reloc_in (abfd, &dst, &n);
1667 bfd_seek (abfd, oldpos, 0);
1668 section->reloc_count = hdr->s_nreloc = n.r_vaddr;
1671 #undef ALIGN_SET
1672 #undef ELIFALIGN_SET
1674 #else /* ! COFF_WITH_PE */
1675 #ifdef RS6000COFF_C
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. */
1681 static void coff_set_alignment_hook PARAMS ((bfd *, asection *, PTR));
1683 static void
1684 coff_set_alignment_hook (abfd, section, scnhdr)
1685 bfd *abfd;
1686 asection *section;
1687 PTR scnhdr;
1689 struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1690 asection *real_sec;
1691 asection **ps;
1693 if ((hdr->s_flags & STYP_OVRFLO) == 0)
1694 return;
1696 real_sec = coff_section_from_bfd_index (abfd, (int) hdr->s_nreloc);
1697 if (real_sec == NULL)
1698 return;
1700 real_sec->reloc_count = hdr->s_paddr;
1701 real_sec->lineno_count = hdr->s_vaddr;
1703 for (ps = &abfd->sections; *ps != NULL; ps = &(*ps)->next)
1705 if (*ps == section)
1707 bfd_section_list_remove (abfd, ps);
1708 --abfd->section_count;
1709 break;
1714 #else /* ! RS6000COFF_C */
1716 #define coff_set_alignment_hook \
1717 ((void (*) PARAMS ((bfd *, asection *, PTR))) bfd_void)
1719 #endif /* ! RS6000COFF_C */
1720 #endif /* ! COFF_WITH_PE */
1721 #endif /* ! COFF_ALIGN_IN_SECTION_HEADER */
1723 #ifndef coff_mkobject
1725 static bfd_boolean coff_mkobject PARAMS ((bfd *));
1727 static bfd_boolean
1728 coff_mkobject (abfd)
1729 bfd * abfd;
1731 coff_data_type *coff;
1732 bfd_size_type amt = sizeof (coff_data_type);
1734 abfd->tdata.coff_obj_data = (struct coff_tdata *) bfd_zalloc (abfd, amt);
1735 if (abfd->tdata.coff_obj_data == 0)
1736 return FALSE;
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;
1744 /* make_abs_section(abfd);*/
1746 return TRUE;
1748 #endif
1750 /* Create the COFF backend specific information. */
1752 #ifndef coff_mkobject_hook
1753 static PTR
1754 coff_mkobject_hook (abfd, filehdr, aouthdr)
1755 bfd * abfd;
1756 PTR filehdr;
1757 PTR aouthdr ATTRIBUTE_UNUSED;
1759 struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1760 coff_data_type *coff;
1762 if (! coff_mkobject (abfd))
1763 return NULL;
1765 coff = coff_data (abfd);
1767 coff->sym_filepos = internal_f->f_symptr;
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;
1776 coff->local_symesz = bfd_coff_symesz (abfd);
1777 coff->local_auxesz = bfd_coff_auxesz (abfd);
1778 coff->local_linesz = bfd_coff_linesz (abfd);
1780 coff->timestamp = internal_f->f_timdat;
1782 obj_raw_syment_count (abfd) =
1783 obj_conv_table_size (abfd) =
1784 internal_f->f_nsyms;
1786 #ifdef RS6000COFF_C
1787 if ((internal_f->f_flags & F_SHROBJ) != 0)
1788 abfd->flags |= DYNAMIC;
1789 if (aouthdr != NULL && internal_f->f_opthdr >= bfd_coff_aoutsz (abfd))
1791 struct internal_aouthdr *internal_a =
1792 (struct internal_aouthdr *) aouthdr;
1793 struct xcoff_tdata *xcoff;
1795 xcoff = xcoff_data (abfd);
1796 # ifdef U803XTOCMAGIC
1797 xcoff->xcoff64 = internal_f->f_magic == U803XTOCMAGIC;
1798 # else
1799 xcoff->xcoff64 = 0;
1800 # endif
1801 xcoff->full_aouthdr = TRUE;
1802 xcoff->toc = internal_a->o_toc;
1803 xcoff->sntoc = internal_a->o_sntoc;
1804 xcoff->snentry = internal_a->o_snentry;
1805 bfd_xcoff_text_align_power (abfd) = internal_a->o_algntext;
1806 bfd_xcoff_data_align_power (abfd) = internal_a->o_algndata;
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;
1812 #endif
1814 #ifdef ARM
1815 /* Set the flags field from the COFF header read in. */
1816 if (! _bfd_coff_arm_set_private_flags (abfd, internal_f->f_flags))
1817 coff->flags = 0;
1818 #endif
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
1827 return (PTR) coff;
1829 #endif
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. */
1838 static bfd_boolean
1839 coff_set_arch_mach_hook (abfd, filehdr)
1840 bfd *abfd;
1841 PTR filehdr;
1843 unsigned long machine;
1844 enum bfd_architecture arch;
1845 struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1847 /* Zero selects the default machine for an arch. */
1848 machine = 0;
1849 switch (internal_f->f_magic)
1851 #ifdef OR32_MAGIC_BIG
1852 case OR32_MAGIC_BIG:
1853 case OR32_MAGIC_LITTLE:
1854 arch = bfd_arch_or32;
1855 break;
1856 #endif
1857 #ifdef PPCMAGIC
1858 case PPCMAGIC:
1859 arch = bfd_arch_powerpc;
1860 break;
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;
1868 break;
1869 #endif
1870 #ifdef IA64MAGIC
1871 case IA64MAGIC:
1872 arch = bfd_arch_ia64;
1873 break;
1874 #endif
1875 #ifdef A29K_MAGIC_BIG
1876 case A29K_MAGIC_BIG:
1877 case A29K_MAGIC_LITTLE:
1878 arch = bfd_arch_a29k;
1879 break;
1880 #endif
1881 #ifdef ARMMAGIC
1882 case ARMMAGIC:
1883 case ARMPEMAGIC:
1884 case THUMBPEMAGIC:
1885 arch = bfd_arch_arm;
1886 switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
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;
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;
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)
1933 case F_Z8001:
1934 machine = bfd_mach_z8001;
1935 break;
1936 case F_Z8002:
1937 machine = bfd_mach_z8002;
1938 break;
1939 default:
1940 return FALSE;
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)
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;
1982 break;
1983 #endif
1984 #endif
1986 #ifdef RS6000COFF_C
1987 #ifdef XCOFF64
1988 case U64_TOCMAGIC:
1989 case U803XTOCMAGIC:
1990 #else
1991 case U802ROMAGIC:
1992 case U802WRMAGIC:
1993 case U802TOCMAGIC:
1994 #endif
1996 int cputype;
1998 if (xcoff_data (abfd)->cputype != -1)
1999 cputype = xcoff_data (abfd)->cputype & 0xff;
2000 else
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
2010 bfd_byte *buf;
2011 struct internal_syment sym;
2012 bfd_size_type amt = bfd_coff_symesz (abfd);
2014 buf = (bfd_byte *) bfd_malloc (amt);
2015 if (bfd_seek (abfd, obj_sym_filepos (abfd), SEEK_SET) != 0
2016 || bfd_bread (buf, amt, abfd) != amt)
2018 free (buf);
2019 return FALSE;
2021 bfd_coff_swap_sym_in (abfd, (PTR) buf, (PTR) &sym);
2022 if (sym.n_sclass == C_FILE)
2023 cputype = sym.n_type & 0xff;
2024 else
2025 cputype = 0;
2026 free (buf);
2030 /* FIXME: We don't handle all cases here. */
2031 switch (cputype)
2033 default:
2034 case 0:
2035 arch = bfd_xcoff_architecture (abfd);
2036 machine = bfd_xcoff_machine (abfd);
2037 break;
2039 case 1:
2040 arch = bfd_arch_powerpc;
2041 machine = bfd_mach_ppc_601;
2042 break;
2043 case 2: /* 64 bit PowerPC */
2044 arch = bfd_arch_powerpc;
2045 machine = bfd_mach_ppc_620;
2046 break;
2047 case 3:
2048 arch = bfd_arch_powerpc;
2049 machine = bfd_mach_ppc;
2050 break;
2051 case 4:
2052 arch = bfd_arch_rs6000;
2053 machine = bfd_mach_rs6k;
2054 break;
2057 break;
2058 #endif
2060 #ifdef WE32KMAGIC
2061 case WE32KMAGIC:
2062 arch = bfd_arch_we32k;
2063 break;
2064 #endif
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
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
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
2093 #ifdef SH_ARCH_MAGIC_BIG
2094 case SH_ARCH_MAGIC_BIG:
2095 case SH_ARCH_MAGIC_LITTLE:
2096 #ifdef COFF_WITH_PE
2097 case SH_ARCH_MAGIC_WINCE:
2098 #endif
2099 arch = bfd_arch_sh;
2100 break;
2101 #endif
2103 #ifdef MIPS_ARCH_MAGIC_WINCE
2104 case MIPS_ARCH_MAGIC_WINCE:
2105 arch = bfd_arch_mips;
2106 break;
2107 #endif
2109 #ifdef H8500MAGIC
2110 case H8500MAGIC:
2111 arch = bfd_arch_h8500;
2112 break;
2113 #endif
2115 #ifdef SPARCMAGIC
2116 case SPARCMAGIC:
2117 #ifdef LYNXCOFFMAGIC
2118 case LYNXCOFFMAGIC:
2119 #endif
2120 arch = bfd_arch_sparc;
2121 break;
2122 #endif
2124 #ifdef TIC30MAGIC
2125 case TIC30MAGIC:
2126 arch = bfd_arch_tic30;
2127 break;
2128 #endif
2130 #ifdef TICOFF0MAGIC
2131 #ifdef TICOFF_TARGET_ARCH
2132 /* This TI COFF section should be used by all new TI COFF v0 targets. */
2133 case TICOFF0MAGIC:
2134 arch = TICOFF_TARGET_ARCH;
2135 machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2136 break;
2137 #endif
2138 #endif
2140 #ifdef TICOFF1MAGIC
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. */
2143 case TICOFF1MAGIC:
2144 case TICOFF2MAGIC:
2145 switch (internal_f->f_target_id)
2147 #ifdef TI_TARGET_ID
2148 case TI_TARGET_ID:
2149 arch = TICOFF_TARGET_ARCH;
2150 machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2151 break;
2152 #endif
2153 default:
2154 arch = bfd_arch_obscure;
2155 (*_bfd_error_handler)
2156 (_("Unrecognized TI COFF target id '0x%x'"),
2157 internal_f->f_target_id);
2158 break;
2160 break;
2161 #endif
2163 #ifdef TIC80_ARCH_MAGIC
2164 case TIC80_ARCH_MAGIC:
2165 arch = bfd_arch_tic80;
2166 break;
2167 #endif
2169 #ifdef MCOREMAGIC
2170 case MCOREMAGIC:
2171 arch = bfd_arch_mcore;
2172 break;
2173 #endif
2175 #ifdef W65MAGIC
2176 case W65MAGIC:
2177 arch = bfd_arch_w65;
2178 break;
2179 #endif
2181 default: /* Unreadable input file type. */
2182 arch = bfd_arch_obscure;
2183 break;
2186 bfd_default_set_arch_mach (abfd, arch, machine);
2187 return TRUE;
2190 #ifdef SYMNAME_IN_DEBUG
2192 static bfd_boolean symname_in_debug_hook
2193 PARAMS ((bfd *, struct internal_syment *));
2195 static bfd_boolean
2196 symname_in_debug_hook (abfd, sym)
2197 bfd * abfd ATTRIBUTE_UNUSED;
2198 struct internal_syment *sym;
2200 return SYMNAME_IN_DEBUG (sym) != 0;
2203 #else
2205 #define symname_in_debug_hook \
2206 (bfd_boolean (*) PARAMS ((bfd *, struct internal_syment *))) bfd_false
2208 #endif
2210 #ifdef RS6000COFF_C
2212 #ifdef XCOFF64
2213 #define FORCE_SYMNAMES_IN_STRINGS
2214 #endif
2216 /* Handle the csect auxent of a C_EXT or C_HIDEXT symbol. */
2218 static bfd_boolean coff_pointerize_aux_hook
2219 PARAMS ((bfd *, combined_entry_type *, combined_entry_type *,
2220 unsigned int, combined_entry_type *));
2222 static bfd_boolean
2223 coff_pointerize_aux_hook (abfd, table_base, symbol, indaux, aux)
2224 bfd *abfd ATTRIBUTE_UNUSED;
2225 combined_entry_type *table_base;
2226 combined_entry_type *symbol;
2227 unsigned int indaux;
2228 combined_entry_type *aux;
2230 int class = symbol->u.syment.n_sclass;
2232 if ((class == C_EXT || class == C_HIDEXT)
2233 && indaux + 1 == symbol->u.syment.n_numaux)
2235 if (SMTYP_SMTYP (aux->u.auxent.x_csect.x_smtyp) == XTY_LD)
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;
2242 /* Return TRUE to indicate that the caller should not do any
2243 further work on this auxent. */
2244 return TRUE;
2247 /* Return FALSE to indicate that this auxent should be handled by
2248 the caller. */
2249 return FALSE;
2252 #else
2253 #ifdef I960
2255 /* We don't want to pointerize bal entries. */
2257 static bfd_boolean coff_pointerize_aux_hook
2258 PARAMS ((bfd *, combined_entry_type *, combined_entry_type *,
2259 unsigned int, combined_entry_type *));
2261 static bfd_boolean
2262 coff_pointerize_aux_hook (abfd, table_base, symbol, indaux, aux)
2263 bfd *abfd ATTRIBUTE_UNUSED;
2264 combined_entry_type *table_base ATTRIBUTE_UNUSED;
2265 combined_entry_type *symbol;
2266 unsigned int indaux;
2267 combined_entry_type *aux ATTRIBUTE_UNUSED;
2269 /* Return TRUE if we don't want to pointerize this aux entry, which
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));
2277 #else /* ! I960 */
2279 #define coff_pointerize_aux_hook 0
2281 #endif /* ! I960 */
2282 #endif /* ! RS6000COFF_C */
2284 /* Print an aux entry. This returns TRUE if it has printed it. */
2286 static bfd_boolean coff_print_aux
2287 PARAMS ((bfd *, FILE *, combined_entry_type *, combined_entry_type *,
2288 combined_entry_type *, unsigned int));
2290 static bfd_boolean
2291 coff_print_aux (abfd, file, table_base, symbol, aux, indaux)
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;
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)
2304 /* This is a csect entry. */
2305 fprintf (file, "AUX ");
2306 if (SMTYP_SMTYP (aux->u.auxent.x_csect.x_smtyp) != XTY_LD)
2308 BFD_ASSERT (! aux->fix_scnlen);
2309 #ifdef XCOFF64
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
2315 else
2317 fprintf (file, "indx ");
2318 if (! aux->fix_scnlen)
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
2324 else
2325 fprintf (file, "%4ld",
2326 (long) (aux->u.auxent.x_csect.x_scnlen.p - table_base));
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);
2337 return TRUE;
2339 #endif
2341 /* Return FALSE to indicate that no special action was taken. */
2342 return FALSE;
2346 SUBSUBSECTION
2347 Writing relocations
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.
2361 #ifdef TARG_AUX
2363 static int compare_arelent_ptr PARAMS ((const PTR, const PTR));
2365 /* AUX's ld wants relocations to be sorted. */
2366 static int
2367 compare_arelent_ptr (x, y)
2368 const PTR x;
2369 const PTR y;
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;
2376 return (aadr < badr ? -1 : badr < aadr ? 1 : 0);
2379 #endif /* TARG_AUX */
2381 static bfd_boolean
2382 coff_write_relocs (abfd, first_undef)
2383 bfd * abfd;
2384 int first_undef;
2386 asection *s;
2388 for (s = abfd->sections; s != (asection *) NULL; s = s->next)
2390 unsigned int i;
2391 struct external_reloc dst;
2392 arelent **p;
2394 #ifndef TARG_AUX
2395 p = s->orelocation;
2396 #else
2398 /* Sort relocations before we write them out. */
2399 bfd_size_type amt;
2401 amt = s->reloc_count;
2402 amt *= sizeof (arelent *);
2403 p = (arelent **) bfd_malloc (amt);
2404 if (p == NULL && s->reloc_count > 0)
2405 return FALSE;
2406 memcpy (p, s->orelocation, (size_t) amt);
2407 qsort (p, s->reloc_count, sizeof (arelent *), compare_arelent_ptr);
2409 #endif
2411 if (bfd_seek (abfd, s->rel_filepos, SEEK_SET) != 0)
2412 return FALSE;
2414 #ifdef COFF_WITH_PE
2415 if (obj_pe (abfd) && s->reloc_count >= 0xffff)
2417 /* Encode real count here as first reloc. */
2418 struct internal_reloc n;
2420 memset ((PTR) & n, 0, sizeof (n));
2421 /* Add one to count *this* reloc (grr). */
2422 n.r_vaddr = s->reloc_count + 1;
2423 coff_swap_reloc_out (abfd, &n, &dst);
2424 if (bfd_bwrite ((PTR) & dst, (bfd_size_type) bfd_coff_relsz (abfd),
2425 abfd) != bfd_coff_relsz (abfd))
2426 return FALSE;
2428 #endif
2430 for (i = 0; i < s->reloc_count; i++)
2432 struct internal_reloc n;
2433 arelent *q = p[i];
2435 memset ((PTR) & n, 0, sizeof (n));
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
2445 have to look up the output symbol here. */
2447 if (q->sym_ptr_ptr[0]->the_bfd != abfd)
2449 int j;
2450 const char *sname = q->sym_ptr_ptr[0]->name;
2451 asymbol **outsyms = abfd->outsymbols;
2453 for (j = first_undef; outsyms[j]; j++)
2455 const char *intable = outsyms[j]->name;
2457 if (strcmp (intable, sname) == 0) {
2458 /* Got a hit, so repoint the reloc. */
2459 q->sym_ptr_ptr = outsyms + j;
2460 break;
2465 n.r_vaddr = q->address + s->vma;
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)
2477 #ifdef SECTION_RELATIVE_ABSOLUTE_SYMBOL_P
2478 if (SECTION_RELATIVE_ABSOLUTE_SYMBOL_P (q,s))
2479 #else
2480 if ((*q->sym_ptr_ptr)->section == bfd_abs_section_ptr
2481 && ((*q->sym_ptr_ptr)->flags & BSF_SECTION_SYM) != 0)
2482 #endif
2483 /* This is a relocation relative to the absolute symbol. */
2484 n.r_symndx = -1;
2485 else
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 ();
2496 #ifdef SWAP_OUT_RELOC_OFFSET
2497 n.r_offset = q->addend;
2498 #endif
2500 #ifdef SELECT_RELOC
2501 /* Work out reloc type from what is required. */
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);
2508 if (bfd_bwrite ((PTR) & dst, (bfd_size_type) bfd_coff_relsz (abfd),
2509 abfd) != bfd_coff_relsz (abfd))
2510 return FALSE;
2513 #ifdef TARG_AUX
2514 if (p != NULL)
2515 free (p);
2516 #endif
2519 return TRUE;
2522 /* Set flags and magic number of a coff file from architecture and machine
2523 type. Result is TRUE if we can represent the arch&type, FALSE if not. */
2525 static bfd_boolean
2526 coff_set_flags (abfd, magicp, flagsp)
2527 bfd * abfd;
2528 unsigned int *magicp ATTRIBUTE_UNUSED;
2529 unsigned short *flagsp ATTRIBUTE_UNUSED;
2531 switch (bfd_get_arch (abfd))
2533 #ifdef Z8KMAGIC
2534 case bfd_arch_z8k:
2535 *magicp = Z8KMAGIC;
2536 switch (bfd_get_mach (abfd))
2538 case bfd_mach_z8001:
2539 *flagsp = F_Z8001;
2540 break;
2541 case bfd_mach_z8002:
2542 *flagsp = F_Z8002;
2543 break;
2544 default:
2545 return FALSE;
2547 return TRUE;
2548 #endif
2549 #ifdef I960ROMAGIC
2551 case bfd_arch_i960:
2554 unsigned flags;
2555 *magicp = I960ROMAGIC;
2557 ((bfd_get_file_flags(abfd) & WP_TEXT) ? I960ROMAGIC :
2558 I960RWMAGIC); FIXME???
2560 switch (bfd_get_mach (abfd))
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:
2587 return FALSE;
2589 *flagsp = flags;
2590 return TRUE;
2592 break;
2593 #endif
2595 #ifdef TIC30MAGIC
2596 case bfd_arch_tic30:
2597 *magicp = TIC30MAGIC;
2598 return TRUE;
2599 #endif
2601 #ifdef TICOFF_DEFAULT_MAGIC
2602 case TICOFF_TARGET_ARCH:
2603 /* If there's no indication of which version we want, use the default. */
2604 if (!abfd->xvec )
2605 *magicp = TICOFF_DEFAULT_MAGIC;
2606 else
2608 /* We may want to output in a different COFF version. */
2609 switch (abfd->xvec->name[4])
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:
2621 return FALSE;
2624 TICOFF_TARGET_MACHINE_SET (flagsp, bfd_get_mach (abfd));
2625 return TRUE;
2626 #endif
2628 #ifdef TIC80_ARCH_MAGIC
2629 case bfd_arch_tic80:
2630 *magicp = TIC80_ARCH_MAGIC;
2631 return TRUE;
2632 #endif
2633 #ifdef ARMMAGIC
2634 case bfd_arch_arm:
2635 #ifdef ARM_WINCE
2636 * magicp = ARMPEMAGIC;
2637 #else
2638 * magicp = ARMMAGIC;
2639 #endif
2640 * flagsp = 0;
2641 if (APCS_SET (abfd))
2643 if (APCS_26_FLAG (abfd))
2644 * flagsp |= F_APCS26;
2646 if (APCS_FLOAT_FLAG (abfd))
2647 * flagsp |= F_APCS_FLOAT;
2649 if (PIC_FLAG (abfd))
2650 * flagsp |= F_PIC;
2652 if (INTERWORK_SET (abfd) && INTERWORK_FLAG (abfd))
2653 * flagsp |= F_INTERWORK;
2654 switch (bfd_get_mach (abfd))
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;
2662 case bfd_mach_arm_5: * flagsp |= F_ARM_5; break;
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(). */
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;
2669 return TRUE;
2670 #endif
2671 #ifdef PPCMAGIC
2672 case bfd_arch_powerpc:
2673 *magicp = PPCMAGIC;
2674 return TRUE;
2675 break;
2676 #endif
2677 #ifdef I386MAGIC
2678 case bfd_arch_i386:
2679 *magicp = I386MAGIC;
2680 #ifdef LYNXOS
2681 /* Just overwrite the usual value if we're doing Lynx. */
2682 *magicp = LYNXCOFFMAGIC;
2683 #endif
2684 return TRUE;
2685 break;
2686 #endif
2687 #ifdef I860MAGIC
2688 case bfd_arch_i860:
2689 *magicp = I860MAGIC;
2690 return TRUE;
2691 break;
2692 #endif
2693 #ifdef IA64MAGIC
2694 case bfd_arch_ia64:
2695 *magicp = IA64MAGIC;
2696 return TRUE;
2697 break;
2698 #endif
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
2712 /* Just overwrite the usual value if we're doing Lynx. */
2713 *magicp = LYNXCOFFMAGIC;
2714 #endif
2715 return TRUE;
2716 break;
2717 #endif
2719 #ifdef MC88MAGIC
2720 case bfd_arch_m88k:
2721 *magicp = MC88OMAGIC;
2722 return TRUE;
2723 break;
2724 #endif
2725 #ifdef H8300MAGIC
2726 case bfd_arch_h8300:
2727 switch (bfd_get_mach (abfd))
2729 case bfd_mach_h8300:
2730 *magicp = H8300MAGIC;
2731 return TRUE;
2732 case bfd_mach_h8300h:
2733 *magicp = H8300HMAGIC;
2734 return TRUE;
2735 case bfd_mach_h8300s:
2736 *magicp = H8300SMAGIC;
2737 return TRUE;
2739 break;
2740 #endif
2742 #ifdef SH_ARCH_MAGIC_BIG
2743 case bfd_arch_sh:
2744 #ifdef COFF_IMAGE_WITH_PE
2745 *magicp = SH_ARCH_MAGIC_WINCE;
2746 #else
2747 if (bfd_big_endian (abfd))
2748 *magicp = SH_ARCH_MAGIC_BIG;
2749 else
2750 *magicp = SH_ARCH_MAGIC_LITTLE;
2751 #endif
2752 return TRUE;
2753 break;
2754 #endif
2756 #ifdef MIPS_ARCH_MAGIC_WINCE
2757 case bfd_arch_mips:
2758 *magicp = MIPS_ARCH_MAGIC_WINCE;
2759 return TRUE;
2760 break;
2761 #endif
2763 #ifdef SPARCMAGIC
2764 case bfd_arch_sparc:
2765 *magicp = SPARCMAGIC;
2766 #ifdef LYNXOS
2767 /* Just overwrite the usual value if we're doing Lynx. */
2768 *magicp = LYNXCOFFMAGIC;
2769 #endif
2770 return TRUE;
2771 break;
2772 #endif
2774 #ifdef H8500MAGIC
2775 case bfd_arch_h8500:
2776 *magicp = H8500MAGIC;
2777 return TRUE;
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;
2786 return TRUE;
2787 break;
2788 #endif
2790 #ifdef WE32KMAGIC
2791 case bfd_arch_we32k:
2792 *magicp = WE32KMAGIC;
2793 return TRUE;
2794 break;
2795 #endif
2797 #ifdef RS6000COFF_C
2798 case bfd_arch_rs6000:
2799 #ifndef PPCMAGIC
2800 case bfd_arch_powerpc:
2801 #endif
2802 BFD_ASSERT (bfd_get_flavour (abfd) == bfd_target_xcoff_flavour);
2803 *magicp = bfd_xcoff_magic_number (abfd);
2804 return TRUE;
2805 break;
2806 #endif
2808 #ifdef MCOREMAGIC
2809 case bfd_arch_mcore:
2810 * magicp = MCOREMAGIC;
2811 return TRUE;
2812 #endif
2814 #ifdef W65MAGIC
2815 case bfd_arch_w65:
2816 *magicp = W65MAGIC;
2817 return TRUE;
2818 #endif
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;
2826 return TRUE;
2827 #endif
2829 default: /* Unknown architecture. */
2830 /* Fall through to "return FALSE" below, to avoid
2831 "statement never reached" errors on the one below. */
2832 break;
2835 return FALSE;
2838 static bfd_boolean
2839 coff_set_arch_mach (abfd, arch, machine)
2840 bfd * abfd;
2841 enum bfd_architecture arch;
2842 unsigned long machine;
2844 unsigned dummy1;
2845 unsigned short dummy2;
2847 if (! bfd_default_set_arch_mach (abfd, arch, machine))
2848 return FALSE;
2850 if (arch != bfd_arch_unknown
2851 && ! coff_set_flags (abfd, &dummy1, &dummy2))
2852 return FALSE; /* We can't represent this type */
2854 return TRUE; /* We're easy ... */
2857 #ifdef COFF_IMAGE_WITH_PE
2859 /* This is used to sort sections by VMA, as required by PE image
2860 files. */
2862 static int sort_by_secaddr PARAMS ((const PTR, const PTR));
2864 static int
2865 sort_by_secaddr (arg1, arg2)
2866 const PTR arg1;
2867 const PTR arg2;
2869 const asection *a = *(const asection **) arg1;
2870 const asection *b = *(const asection **) arg2;
2872 if (a->vma < b->vma)
2873 return -1;
2874 else if (a->vma > b->vma)
2875 return 1;
2876 else
2877 return 0;
2880 #endif /* COFF_IMAGE_WITH_PE */
2882 /* Calculate the file position for each section. */
2884 #ifndef I960
2885 #define ALIGN_SECTIONS_IN_FILE
2886 #endif
2887 #if defined(TIC80COFF) || defined(TICOFF)
2888 #undef ALIGN_SECTIONS_IN_FILE
2889 #endif
2891 static bfd_boolean
2892 coff_compute_section_file_positions (abfd)
2893 bfd * abfd;
2895 asection *current;
2896 asection *previous = (asection *) NULL;
2897 file_ptr sofar = bfd_coff_filhsz (abfd);
2898 bfd_boolean align_adjust;
2899 #ifdef ALIGN_SECTIONS_IN_FILE
2900 file_ptr old_sofar;
2901 #endif
2903 #ifdef RS6000COFF_C
2904 /* On XCOFF, if we have symbols, set up the .debug section. */
2905 if (bfd_get_symcount (abfd) > 0)
2907 bfd_size_type sz;
2908 bfd_size_type i, symcount;
2909 asymbol **symp;
2911 sz = 0;
2912 symcount = bfd_get_symcount (abfd);
2913 for (symp = abfd->outsymbols, i = 0; i < symcount; symp++, i++)
2915 coff_symbol_type *cf;
2917 cf = coff_symbol_from (abfd, *symp);
2918 if (cf != NULL
2919 && cf->native != NULL
2920 && SYMNAME_IN_DEBUG (&cf->native->u.syment))
2922 size_t len;
2924 len = strlen (bfd_asymbol_name (*symp));
2925 if (len > SYMNMLEN || bfd_coff_force_symnames_in_strings (abfd))
2926 sz += len + 1 + bfd_coff_debug_string_prefix_length (abfd);
2929 if (sz > 0)
2931 asection *dsec;
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;
2940 #endif
2942 #ifdef COFF_IMAGE_WITH_PE
2943 int page_size;
2944 if (coff_data (abfd)->link_info)
2946 page_size = pe_data (abfd)->pe_opthdr.FileAlignment;
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
2956 if (bfd_get_start_address (abfd))
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;
2963 if (abfd->flags & EXEC_P)
2964 sofar += bfd_coff_aoutsz (abfd);
2965 #ifdef RS6000COFF_C
2966 else if (xcoff_data (abfd)->full_aouthdr)
2967 sofar += bfd_coff_aoutsz (abfd);
2968 else
2969 sofar += SMALL_AOUTSZ;
2970 #endif
2972 sofar += abfd->section_count * bfd_coff_scnhsz (abfd);
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)
2979 sofar += bfd_coff_scnhsz (abfd);
2980 #endif
2982 #ifdef COFF_IMAGE_WITH_PE
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. */
2990 unsigned int count;
2991 asection **section_list;
2992 unsigned int i;
2993 int target_index;
2994 bfd_size_type amt;
2996 count = 0;
2997 for (current = abfd->sections; current != NULL; current = current->next)
2998 ++count;
3000 /* We allocate an extra cell to simplify the final loop. */
3001 amt = sizeof (struct asection *) * (count + 1);
3002 section_list = bfd_malloc (amt);
3003 if (section_list == NULL)
3004 return FALSE;
3006 i = 0;
3007 for (current = abfd->sections; current != NULL; current = current->next)
3009 section_list[i] = current;
3010 ++i;
3012 section_list[i] = NULL;
3014 qsort (section_list, count, sizeof (asection *), sort_by_secaddr);
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++)
3022 current = section_list[i];
3023 current->next = section_list[i + 1];
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)
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;
3039 else
3040 current->target_index = target_index++;
3042 abfd->section_tail = &current->next;
3044 free (section_list);
3046 #else /* ! COFF_IMAGE_WITH_PE */
3048 /* Set the target_index field. */
3049 int target_index;
3051 target_index = 1;
3052 for (current = abfd->sections; current != NULL; current = current->next)
3053 current->target_index = target_index++;
3055 #endif /* ! COFF_IMAGE_WITH_PE */
3057 align_adjust = FALSE;
3058 for (current = abfd->sections;
3059 current != (asection *) NULL;
3060 current = current->next)
3062 #ifdef COFF_IMAGE_WITH_PE
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)
3067 bfd_size_type amt = sizeof (struct coff_section_tdata);
3068 current->used_by_bfd = (PTR) bfd_zalloc (abfd, amt);
3069 if (current->used_by_bfd == NULL)
3070 return FALSE;
3072 if (pei_section_data (abfd, current) == NULL)
3074 bfd_size_type amt = sizeof (struct pei_section_tdata);
3075 coff_section_data (abfd, current)->tdata
3076 = (PTR) bfd_zalloc (abfd, amt);
3077 if (coff_section_data (abfd, current)->tdata == NULL)
3078 return FALSE;
3080 if (pei_section_data (abfd, current)->virt_size == 0)
3081 pei_section_data (abfd, current)->virt_size = current->_raw_size;
3082 #endif
3084 /* Only deal with sections which have contents. */
3085 if (!(current->flags & SEC_HAS_CONTENTS))
3086 continue;
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
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
3097 doesn't yet page from files... */
3098 #ifdef ALIGN_SECTIONS_IN_FILE
3099 if ((abfd->flags & EXEC_P) != 0)
3101 /* Make sure this section is aligned on the right boundary - by
3102 padding the previous section up if necessary. */
3104 old_sofar = sofar;
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
3108 AIX executables, this check fails. This shows up when a native
3109 AIX executable is stripped with gnu strip because the default vma
3110 of native is 0x10000150 but default for gnu is 0x10000140. Gnu
3111 stripped gnu excutable passes this check because the filepos is
3112 0x0140. This problem also show up with 64 bit shared objects. The
3113 data section must also be aligned. */
3114 if (!strcmp (current->name, _TEXT)
3115 || !strcmp (current->name, _DATA))
3117 bfd_vma pad;
3118 bfd_vma align;
3120 sofar = BFD_ALIGN (sofar, 1 << current->alignment_power);
3122 align = 1 << current->alignment_power;
3123 pad = abs (current->vma - sofar) % align;
3125 if (pad)
3127 pad = align - pad;
3128 sofar += pad;
3131 else
3132 #else
3134 sofar = BFD_ALIGN (sofar, 1 << current->alignment_power);
3136 #endif
3137 if (previous != (asection *) NULL)
3138 previous->_raw_size += sofar - old_sofar;
3141 #endif
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;
3152 #ifdef COFF_IMAGE_WITH_PE
3153 /* Set the padded size. */
3154 current->_raw_size = (current->_raw_size + page_size -1) & -page_size;
3155 #endif
3157 sofar += current->_raw_size;
3159 #ifdef ALIGN_SECTIONS_IN_FILE
3160 /* Make sure that this section is of the right size too. */
3161 if ((abfd->flags & EXEC_P) == 0)
3163 bfd_size_type old_size;
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;
3171 else
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;
3178 #endif
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)
3185 align_adjust = TRUE;
3186 #endif
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
3196 previous = current;
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)
3206 bfd_byte b;
3208 b = 0;
3209 if (bfd_seek (abfd, sofar - 1, SEEK_SET) != 0
3210 || bfd_bwrite (&b, (bfd_size_type) 1, abfd) != 1)
3211 return FALSE;
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);
3219 obj_relocbase (abfd) = sofar;
3220 abfd->output_has_begun = TRUE;
3222 return TRUE;
3225 #if 0
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. */
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? */
3234 static bfd_boolean
3235 coff_add_missing_symbols (abfd)
3236 bfd *abfd;
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;
3243 bfd_size_type amt;
3245 for (i = 0; i < nsyms; i++)
3247 coff_symbol_type *csym = coff_symbol_from (abfd, sympp[i]);
3248 const char *name;
3250 if (csym)
3252 /* Only do this if there is a coff representation of the input
3253 symbol. */
3254 if (csym->native && csym->native->u.syment.n_sclass == C_FILE)
3256 need_file = 0;
3257 continue;
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;
3274 /* Now i == bfd_get_symcount (abfd). */
3275 /* @@ For now, don't deal with .file symbol. */
3276 need_file = 0;
3278 if (!need_text && !need_data && !need_bss && !need_file)
3279 return TRUE;
3280 nsyms += need_text + need_data + need_bss + need_file;
3281 amt = nsyms;
3282 amt *= sizeof (asymbol *);
3283 sympp2 = (asymbol **) bfd_alloc (abfd, amt);
3284 if (!sympp2)
3285 return FALSE;
3286 memcpy (sympp2, sympp, i * sizeof (asymbol *));
3288 if (need_file)
3289 /* @@ Generate fake .file symbol, in sympp2[i], and increment i. */
3290 abort ();
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);
3300 return TRUE;
3303 #endif /* 0 */
3305 #ifdef COFF_IMAGE_WITH_PE
3307 static unsigned int pelength;
3308 static unsigned int peheader;
3310 static bfd_boolean
3311 coff_read_word (abfd, value)
3312 bfd *abfd;
3313 unsigned int *value;
3315 unsigned char b[2];
3316 int status;
3318 status = bfd_bread (b, (bfd_size_type) 2, abfd);
3319 if (status < 1)
3321 *value = 0;
3322 return FALSE;
3325 if (status == 1)
3326 *value = (unsigned int) b[0];
3327 else
3328 *value = (unsigned int) (b[0] + (b[1] << 8));
3330 pelength += (unsigned int) status;
3332 return TRUE;
3335 static unsigned int
3336 coff_compute_checksum (abfd)
3337 bfd *abfd;
3339 bfd_boolean more_data;
3340 file_ptr filepos;
3341 unsigned int value;
3342 unsigned int total;
3344 total = 0;
3345 pelength = 0;
3346 filepos = (file_ptr) 0;
3350 if (bfd_seek (abfd, filepos, SEEK_SET) != 0)
3351 return 0;
3353 more_data = coff_read_word (abfd, &value);
3354 total += value;
3355 total = 0xffff & (total + (total >> 0x10));
3356 filepos += 2;
3358 while (more_data);
3360 return (0xffff & (total + (total >> 0x10)));
3363 static bfd_boolean
3364 coff_apply_checksum (abfd)
3365 bfd *abfd;
3367 unsigned int computed;
3368 unsigned int checksum = 0;
3370 if (bfd_seek (abfd, 0x3c, SEEK_SET) != 0)
3371 return FALSE;
3373 if (!coff_read_word (abfd, &peheader))
3374 return FALSE;
3376 if (bfd_seek (abfd, peheader + 0x58, SEEK_SET) != 0)
3377 return FALSE;
3379 checksum = 0;
3380 bfd_bwrite (&checksum, (bfd_size_type) 4, abfd);
3382 if (bfd_seek (abfd, peheader, SEEK_SET) != 0)
3383 return FALSE;
3385 computed = coff_compute_checksum (abfd);
3387 checksum = computed + pelength;
3389 if (bfd_seek (abfd, peheader + 0x58, SEEK_SET) != 0)
3390 return FALSE;
3392 bfd_bwrite (&checksum, (bfd_size_type) 4, abfd);
3394 return TRUE;
3397 #endif /* COFF_IMAGE_WITH_PE */
3399 /* SUPPRESS 558 */
3400 /* SUPPRESS 529 */
3401 static bfd_boolean
3402 coff_write_object_contents (abfd)
3403 bfd * abfd;
3405 asection *current;
3406 bfd_boolean hasrelocs = FALSE;
3407 bfd_boolean haslinno = FALSE;
3408 bfd_boolean hasdebug = FALSE;
3409 file_ptr scn_base;
3410 file_ptr reloc_base;
3411 file_ptr lineno_base;
3412 file_ptr sym_base;
3413 unsigned long reloc_size = 0, reloc_count = 0;
3414 unsigned long lnno_size = 0;
3415 bfd_boolean long_section_names;
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
3425 bfd_set_error (bfd_error_system_call);
3427 /* Make a pass through the symbol table to count line number entries and
3428 put them into the correct asections. */
3430 lnno_size = coff_count_linenumbers (abfd) * bfd_coff_linesz (abfd);
3432 if (! abfd->output_has_begun)
3434 if (! coff_compute_section_file_positions (abfd))
3435 return FALSE;
3438 reloc_base = obj_relocbase (abfd);
3440 /* Work out the size of the reloc and linno areas. */
3442 for (current = abfd->sections; current != NULL; current =
3443 current->next)
3445 #ifdef COFF_WITH_PE
3446 /* We store the actual reloc count in the first reloc's addr. */
3447 if (obj_pe (abfd) && current->reloc_count >= 0xffff)
3448 reloc_count ++;
3449 #endif
3450 reloc_count += current->reloc_count;
3453 reloc_size = reloc_count * bfd_coff_relsz (abfd);
3455 lineno_base = reloc_base + reloc_size;
3456 sym_base = lineno_base + lnno_size;
3458 /* Indicate in each section->line_filepos its actual file address. */
3459 for (current = abfd->sections; current != NULL; current =
3460 current->next)
3462 if (current->lineno_count)
3464 current->line_filepos = lineno_base;
3465 current->moving_line_filepos = lineno_base;
3466 lineno_base += current->lineno_count * bfd_coff_linesz (abfd);
3468 else
3470 current->line_filepos = 0;
3472 if (current->reloc_count)
3474 current->rel_filepos = reloc_base;
3475 reloc_base += current->reloc_count * bfd_coff_relsz (abfd);
3476 #ifdef COFF_WITH_PE
3477 /* Extra reloc to hold real count. */
3478 if (obj_pe (abfd) && current->reloc_count >= 0xffff)
3479 reloc_base += bfd_coff_relsz (abfd);
3480 #endif
3482 else
3484 current->rel_filepos = 0;
3488 /* Write section headers to the file. */
3489 internal_f.f_nscns = 0;
3491 if ((abfd->flags & EXEC_P) != 0)
3492 scn_base = bfd_coff_filhsz (abfd) + bfd_coff_aoutsz (abfd);
3493 else
3495 scn_base = bfd_coff_filhsz (abfd);
3496 #ifdef RS6000COFF_C
3497 #ifndef XCOFF64
3498 if (xcoff_data (abfd)->full_aouthdr)
3499 scn_base += bfd_coff_aoutsz (abfd);
3500 else
3501 scn_base += SMALL_AOUTSZ;
3502 #endif
3503 #endif
3506 if (bfd_seek (abfd, scn_base, SEEK_SET) != 0)
3507 return FALSE;
3509 long_section_names = FALSE;
3510 for (current = abfd->sections;
3511 current != NULL;
3512 current = current->next)
3514 struct internal_scnhdr section;
3515 bfd_boolean is_reloc_section = FALSE;
3517 #ifdef COFF_IMAGE_WITH_PE
3518 if (strcmp (current->name, ".reloc") == 0)
3520 is_reloc_section = TRUE;
3521 hasrelocs = TRUE;
3522 pe_data (abfd)->has_reloc_section = 1;
3524 #endif
3526 internal_f.f_nscns++;
3528 strncpy (section.s_name, current->name, SCNNMLEN);
3530 #ifdef COFF_LONG_SECTION_NAMES
3531 /* Handle long section names as in PE. This must be compatible
3532 with the code in coff_write_symbols and _bfd_coff_final_link. */
3534 size_t len;
3536 len = strlen (current->name);
3537 if (len > SCNNMLEN)
3539 memset (section.s_name, 0, SCNNMLEN);
3540 sprintf (section.s_name, "/%lu", (unsigned long) string_size);
3541 string_size += len + 1;
3542 long_section_names = TRUE;
3545 #endif
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;
3557 #ifdef coff_get_section_load_page
3558 section.s_page = coff_get_section_load_page (current);
3559 #endif
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
3573 /* If this section has no size or is unloadable then the scnptr
3574 will be 0 too. */
3575 if (current->_raw_size == 0 ||
3576 (current->flags & (SEC_LOAD | SEC_HAS_CONTENTS)) == 0)
3577 section.s_scnptr = 0;
3578 else
3579 section.s_scnptr = current->filepos;
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;
3585 #ifndef COFF_IMAGE_WITH_PE
3586 /* In PEI, relocs come in the .reloc section. */
3587 if (current->reloc_count != 0)
3588 hasrelocs = TRUE;
3589 #endif
3590 if (current->lineno_count != 0)
3591 haslinno = TRUE;
3592 if ((current->flags & SEC_DEBUGGING) != 0
3593 && ! is_reloc_section)
3594 hasdebug = TRUE;
3596 #ifdef RS6000COFF_C
3597 #ifndef XCOFF64
3598 /* Indicate the use of an XCOFF overflow section header. */
3599 if (current->reloc_count >= 0xffff || current->lineno_count >= 0xffff)
3601 section.s_nreloc = 0xffff;
3602 section.s_nlnno = 0xffff;
3604 #endif
3605 #endif
3607 section.s_flags = sec_to_styp_flags (current->name, current->flags);
3609 if (!strcmp (current->name, _TEXT))
3610 text_sec = current;
3611 else if (!strcmp (current->name, _DATA))
3612 data_sec = current;
3613 else if (!strcmp (current->name, _BSS))
3614 bss_sec = current;
3616 #ifdef I960
3617 section.s_align = (current->alignment_power
3618 ? 1 << current->alignment_power
3619 : 0);
3620 #endif
3621 #ifdef TIC80COFF
3622 /* TI COFF puts the alignment power in bits 8-11 of the flags. */
3623 section.s_flags |= (current->alignment_power & 0xF) << 8;
3624 #endif
3625 #ifdef COFF_ENCODE_ALIGNMENT
3626 COFF_ENCODE_ALIGNMENT(section, current->alignment_power);
3627 #endif
3629 #ifdef COFF_IMAGE_WITH_PE
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. */
3635 if (section.s_size == 0)
3636 internal_f.f_nscns--;
3637 else
3638 #endif
3640 SCNHDR buff;
3641 bfd_size_type amt = bfd_coff_scnhsz (abfd);
3643 if (coff_swap_scnhdr_out (abfd, &section, &buff) == 0
3644 || bfd_bwrite ((PTR) &buff, amt, abfd) != amt)
3645 return FALSE;
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)
3654 unsigned int i, count;
3655 asymbol **psym;
3656 coff_symbol_type *csym = NULL;
3657 asymbol **psymsec;
3659 psymsec = NULL;
3660 count = bfd_get_symcount (abfd);
3661 for (i = 0, psym = abfd->outsymbols; i < count; i++, psym++)
3663 if ((*psym)->section != current)
3664 continue;
3666 /* Remember the location of the first symbol in this
3667 section. */
3668 if (psymsec == NULL)
3669 psymsec = psym;
3671 /* See if this is the section symbol. */
3672 if (strcmp ((*psym)->name, current->name) == 0)
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;
3682 /* Here *PSYM is the section symbol for CURRENT. */
3684 break;
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)
3693 combined_entry_type *aux;
3695 /* We don't touch the x_checksum field. The
3696 x_associated field is not currently supported. */
3698 aux = csym->native + 1;
3699 switch (current->flags & SEC_LINK_DUPLICATES)
3701 case SEC_LINK_DUPLICATES_DISCARD:
3702 aux->u.auxent.x_scn.x_comdat = IMAGE_COMDAT_SELECT_ANY;
3703 break;
3705 case SEC_LINK_DUPLICATES_ONE_ONLY:
3706 aux->u.auxent.x_scn.x_comdat =
3707 IMAGE_COMDAT_SELECT_NODUPLICATES;
3708 break;
3710 case SEC_LINK_DUPLICATES_SAME_SIZE:
3711 aux->u.auxent.x_scn.x_comdat =
3712 IMAGE_COMDAT_SELECT_SAME_SIZE;
3713 break;
3715 case SEC_LINK_DUPLICATES_SAME_CONTENTS:
3716 aux->u.auxent.x_scn.x_comdat =
3717 IMAGE_COMDAT_SELECT_EXACT_MATCH;
3718 break;
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)
3730 asymbol *hold;
3731 asymbol **pcopy;
3733 hold = *psym;
3734 for (pcopy = psym; pcopy > psymsec; pcopy--)
3735 pcopy[0] = pcopy[-1];
3736 *psymsec = hold;
3740 #endif /* COFF_WITH_PE */
3743 #ifdef RS6000COFF_C
3744 #ifndef XCOFF64
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)
3749 if (current->reloc_count >= 0xffff || current->lineno_count >= 0xffff)
3751 struct internal_scnhdr scnhdr;
3752 SCNHDR buff;
3753 bfd_size_type amt;
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;
3766 amt = bfd_coff_scnhsz (abfd);
3767 if (coff_swap_scnhdr_out (abfd, &scnhdr, &buff) == 0
3768 || bfd_bwrite ((PTR) &buff, amt, abfd) != amt)
3769 return FALSE;
3772 #endif
3773 #endif
3775 /* OK, now set up the filehdr... */
3777 /* Don't include the internal abs section in the section count */
3779 /* We will NOT put a fucking timestamp in the header here. Every time you
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
3782 same but is not a reasonable time. -- gnu@cygnus.com */
3783 internal_f.f_timdat = 0;
3784 internal_f.f_flags = 0;
3786 if (abfd->flags & EXEC_P)
3787 internal_f.f_opthdr = bfd_coff_aoutsz (abfd);
3788 else
3790 internal_f.f_opthdr = 0;
3791 #ifdef RS6000COFF_C
3792 #ifndef XCOFF64
3793 if (xcoff_data (abfd)->full_aouthdr)
3794 internal_f.f_opthdr = bfd_coff_aoutsz (abfd);
3795 else
3796 internal_f.f_opthdr = SMALL_AOUTSZ;
3797 #endif
3798 #endif
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;
3807 #ifdef COFF_IMAGE_WITH_PE
3808 if (! hasdebug)
3809 internal_f.f_flags |= IMAGE_FILE_DEBUG_STRIPPED;
3810 #endif
3812 #ifndef COFF_WITH_PE
3813 if (bfd_little_endian (abfd))
3814 internal_f.f_flags |= F_AR32WR;
3815 else
3816 internal_f.f_flags |= F_AR32W;
3817 #endif
3819 #ifdef TI_TARGET_ID
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. */
3822 internal_f.f_target_id = TI_TARGET_ID;
3823 #endif
3824 #ifdef TIC80_TARGET_ID
3825 internal_f.f_target_id = TIC80_TARGET_ID;
3826 #endif
3828 /* FIXME, should do something about the other byte orders and
3829 architectures. */
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
3838 memset (&internal_a, 0, sizeof internal_a);
3840 /* Set up architecture-dependent stuff. */
3842 unsigned int magic = 0;
3843 unsigned short flags = 0;
3845 coff_set_flags (abfd, &magic, &flags);
3846 internal_f.f_magic = magic;
3847 internal_f.f_flags |= flags;
3848 /* ...and the "opt"hdr... */
3850 #ifdef A29K
3851 #ifdef ULTRA3 /* NYU's machine */
3852 /* FIXME: This is a bogus check. I really want to see if there
3853 is a .shbss or a .shdata section, if so then set the magic
3854 number to indicate a shared data executable. */
3855 if (internal_f.f_nscns >= 7)
3856 internal_a.magic = SHMAGIC; /* Shared magic. */
3857 else
3858 #endif /* ULTRA3 */
3859 internal_a.magic = NMAGIC; /* Assume separate i/d. */
3860 #define __A_MAGIC_SET__
3861 #endif /* A29K */
3862 #ifdef TICOFF_AOUT_MAGIC
3863 internal_a.magic = TICOFF_AOUT_MAGIC;
3864 #define __A_MAGIC_SET__
3865 #endif
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 */
3884 #if APOLLO_M68
3885 #define __A_MAGIC_SET__
3886 internal_a.magic = APOLLO_COFF_VERSION_NUMBER;
3887 #endif
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 */
3906 #if defined(ARM)
3907 #define __A_MAGIC_SET__
3908 internal_a.magic = ZMAGIC;
3909 #endif
3911 #if defined(PPC_PE)
3912 #define __A_MAGIC_SET__
3913 internal_a.magic = IMAGE_NT_OPTIONAL_HDR_MAGIC;
3914 #endif
3916 #if defined MCORE_PE
3917 #define __A_MAGIC_SET__
3918 internal_a.magic = IMAGE_NT_OPTIONAL_HDR_MAGIC;
3919 #endif
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 */
3930 #if defined(IA64)
3931 #define __A_MAGIC_SET__
3932 internal_a.magic = ZMAGIC;
3933 #endif /* IA64 */
3935 #if defined(SPARC)
3936 #define __A_MAGIC_SET__
3937 #if defined(LYNXOS)
3938 internal_a.magic = LYNXCOFFMAGIC;
3939 #endif /* LYNXOS */
3940 #endif /* SPARC */
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
3949 #if defined(SH) && defined(COFF_WITH_PE)
3950 #define __A_MAGIC_SET__
3951 internal_a.magic = SH_PE_MAGIC;
3952 #endif
3954 #if defined(MIPS) && defined(COFF_WITH_PE)
3955 #define __A_MAGIC_SET__
3956 internal_a.magic = MIPS_PE_MAGIC;
3957 #endif
3959 #ifdef OR32
3960 #define __A_MAGIC_SET__
3961 internal_a.magic = NMAGIC; /* Assume separate i/d. */
3962 #endif
3964 #ifndef __A_MAGIC_SET__
3965 #include "Your aouthdr magic number is not being set!"
3966 #else
3967 #undef __A_MAGIC_SET__
3968 #endif
3971 /* FIXME: Does anybody ever set this to another value? */
3972 internal_a.vstamp = 0;
3974 /* Now should write relocs, strings, syms. */
3975 obj_sym_filepos (abfd) = sym_base;
3977 if (bfd_get_symcount (abfd) != 0)
3979 int firstundef;
3980 #if 0
3981 if (!coff_add_missing_symbols (abfd))
3982 return FALSE;
3983 #endif
3984 if (!coff_renumber_symbols (abfd, &firstundef))
3985 return FALSE;
3986 coff_mangle_symbols (abfd);
3987 if (! coff_write_symbols (abfd))
3988 return FALSE;
3989 if (! coff_write_linenumbers (abfd))
3990 return FALSE;
3991 if (! coff_write_relocs (abfd, firstundef))
3992 return FALSE;
3994 #ifdef COFF_LONG_SECTION_NAMES
3995 else if (long_section_names && ! obj_coff_strings_written (abfd))
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))
4000 return FALSE;
4002 #endif
4003 #ifdef COFF_IMAGE_WITH_PE
4004 #ifdef PPC_PE
4005 else if ((abfd->flags & EXEC_P) != 0)
4007 bfd_byte b;
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,
4013 (file_ptr) BFD_ALIGN (sym_base, COFF_PAGE_SIZE) - 1,
4014 SEEK_SET) != 0
4015 || bfd_bwrite (&b, (bfd_size_type) 1, abfd) != 1)
4016 return FALSE;
4018 #endif
4019 #endif
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)
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
4033 else
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;
4042 if (text_sec)
4044 internal_a.tsize = bfd_get_section_size_before_reloc (text_sec);
4045 internal_a.text_start = internal_a.tsize ? text_sec->vma : 0;
4047 if (data_sec)
4049 internal_a.dsize = bfd_get_section_size_before_reloc (data_sec);
4050 internal_a.data_start = internal_a.dsize ? data_sec->vma : 0;
4052 if (bss_sec)
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;
4059 internal_a.entry = bfd_get_start_address (abfd);
4060 internal_f.f_nsyms = obj_raw_syment_count (abfd);
4062 #ifdef RS6000COFF_C
4063 if (xcoff_data (abfd)->full_aouthdr)
4065 bfd_vma toc;
4066 asection *loader_sec;
4068 internal_a.vstamp = 1;
4070 internal_a.o_snentry = xcoff_data (abfd)->snentry;
4071 if (internal_a.o_snentry == 0)
4072 internal_a.entry = (bfd_vma) -1;
4074 if (text_sec != NULL)
4076 internal_a.o_sntext = text_sec->target_index;
4077 internal_a.o_algntext = bfd_get_section_alignment (abfd, text_sec);
4079 else
4081 internal_a.o_sntext = 0;
4082 internal_a.o_algntext = 0;
4084 if (data_sec != NULL)
4086 internal_a.o_sndata = data_sec->target_index;
4087 internal_a.o_algndata = bfd_get_section_alignment (abfd, data_sec);
4089 else
4091 internal_a.o_sndata = 0;
4092 internal_a.o_algndata = 0;
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;
4104 toc = xcoff_data (abfd)->toc;
4105 internal_a.o_toc = toc;
4106 internal_a.o_sntoc = xcoff_data (abfd)->sntoc;
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
4113 switch (bfd_get_arch (abfd))
4115 case bfd_arch_rs6000:
4116 internal_a.o_cputype = 4;
4117 break;
4118 case bfd_arch_powerpc:
4119 if (bfd_get_mach (abfd) == bfd_mach_ppc)
4120 internal_a.o_cputype = 3;
4121 else
4122 internal_a.o_cputype = 1;
4123 break;
4124 default:
4125 abort ();
4128 internal_a.o_maxstack = xcoff_data (abfd)->maxstack;
4129 internal_a.o_maxdata = xcoff_data (abfd)->maxdata;
4131 #endif
4133 /* now write them */
4134 if (bfd_seek (abfd, (file_ptr) 0, SEEK_SET) != 0)
4135 return FALSE;
4138 char * buff;
4139 bfd_size_type amount = bfd_coff_filhsz (abfd);
4141 buff = bfd_malloc (amount);
4142 if (buff == NULL)
4143 return FALSE;
4145 bfd_coff_swap_filehdr_out (abfd, (PTR) &internal_f, (PTR) buff);
4146 amount = bfd_bwrite ((PTR) buff, amount, abfd);
4148 free (buff);
4150 if (amount != bfd_coff_filhsz (abfd))
4151 return FALSE;
4154 if (abfd->flags & EXEC_P)
4156 /* Note that peicode.h fills in a PEAOUTHDR, not an AOUTHDR.
4157 include/coff/pe.h sets AOUTSZ == sizeof (PEAOUTHDR)). */
4158 char * buff;
4159 bfd_size_type amount = bfd_coff_aoutsz (abfd);
4161 buff = bfd_malloc (amount);
4162 if (buff == NULL)
4163 return FALSE;
4165 coff_swap_aouthdr_out (abfd, (PTR) &internal_a, (PTR) buff);
4166 amount = bfd_bwrite ((PTR) buff, amount, abfd);
4168 free (buff);
4170 if (amount != bfd_coff_aoutsz (abfd))
4171 return FALSE;
4173 #ifdef COFF_IMAGE_WITH_PE
4174 if (! coff_apply_checksum (abfd))
4175 return FALSE;
4176 #endif
4178 #ifdef RS6000COFF_C
4179 else
4181 AOUTHDR buff;
4182 size_t size;
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)
4187 size = bfd_coff_aoutsz (abfd);
4188 else
4189 size = SMALL_AOUTSZ;
4190 if (bfd_bwrite ((PTR) &buff, (bfd_size_type) size, abfd) != size)
4191 return FALSE;
4193 #endif
4195 return TRUE;
4198 static bfd_boolean
4199 coff_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;
4206 if (! abfd->output_has_begun) /* Set by bfd.c handler. */
4208 if (! coff_compute_section_file_positions (abfd))
4209 return FALSE;
4212 #if defined(_LIB) && !defined(TARG_AUX)
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.
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:
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.
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!).
4233 Gvran Uddeborg <gvran@uddeborg.pp.se>. */
4235 if (strcmp (section->name, _LIB) == 0)
4237 bfd_byte *rec, *recend;
4239 rec = (bfd_byte *) location;
4240 recend = rec + count;
4241 while (rec < recend)
4243 ++section->lma;
4244 rec += bfd_get_32 (abfd, rec) * 4;
4247 BFD_ASSERT (rec == recend);
4250 #endif
4252 /* Don't write out bss sections - one way to do this is to
4253 see if the filepos has not been set. */
4254 if (section->filepos == 0)
4255 return TRUE;
4257 if (bfd_seek (abfd, section->filepos + offset, SEEK_SET) != 0)
4258 return FALSE;
4260 if (count == 0)
4261 return TRUE;
4263 return bfd_bwrite (location, count, abfd) == count;
4265 #if 0
4266 static bfd_boolean
4267 coff_close_and_cleanup (abfd)
4268 bfd *abfd;
4270 if (!bfd_read_p (abfd))
4271 switch (abfd->format)
4273 case bfd_archive:
4274 if (!_bfd_write_archive_contents (abfd))
4275 return FALSE;
4276 break;
4277 case bfd_object:
4278 if (!coff_write_object_contents (abfd))
4279 return FALSE;
4280 break;
4281 default:
4282 bfd_set_error (bfd_error_invalid_operation);
4283 return FALSE;
4286 /* We depend on bfd_close to free all the memory on the objalloc. */
4287 return TRUE;
4290 #endif
4292 static PTR
4293 buy_and_read (abfd, where, size)
4294 bfd *abfd;
4295 file_ptr where;
4296 bfd_size_type size;
4298 PTR area = (PTR) bfd_alloc (abfd, size);
4299 if (!area)
4300 return (NULL);
4301 if (bfd_seek (abfd, where, SEEK_SET) != 0
4302 || bfd_bread (area, size, abfd) != size)
4303 return (NULL);
4304 return (area);
4305 } /* buy_and_read() */
4308 SUBSUBSECTION
4309 Reading linenumbers
4311 Creating the linenumber table is done by reading in the entire
4312 coff linenumber table, and creating another table for internal use.
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.
4320 Note: The PE format uses line number 0 for a flag indicating a
4321 new source file.
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...
4327 How does this work ?
4331 static bfd_boolean
4332 coff_slurp_line_table (abfd, asect)
4333 bfd *abfd;
4334 asection *asect;
4336 LINENO *native_lineno;
4337 alent *lineno_cache;
4338 bfd_size_type amt;
4340 BFD_ASSERT (asect->lineno == (alent *) NULL);
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);
4346 if (lineno_cache == NULL)
4347 return FALSE;
4348 else
4350 unsigned int counter = 0;
4351 alent *cache_ptr = lineno_cache;
4352 LINENO *src = native_lineno;
4354 while (counter < asect->lineno_count)
4356 struct internal_lineno dst;
4358 bfd_coff_swap_lineno_in (abfd, src, &dst);
4359 cache_ptr->line_number = dst.l_lnno;
4361 if (cache_ptr->line_number == 0)
4363 bfd_boolean warned;
4364 bfd_signed_vma symndx;
4365 coff_symbol_type *sym;
4367 warned = FALSE;
4368 symndx = dst.l_addr.l_symndx;
4369 if (symndx < 0
4370 || (bfd_vma) symndx >= obj_raw_syment_count (abfd))
4372 (*_bfd_error_handler)
4373 (_("%s: warning: illegal symbol index %ld in line numbers"),
4374 bfd_archive_filename (abfd), dst.l_addr.l_symndx);
4375 symndx = 0;
4376 warned = TRUE;
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)
4386 (*_bfd_error_handler)
4387 (_("%s: warning: duplicate line number information for `%s'"),
4388 bfd_archive_filename (abfd),
4389 bfd_asymbol_name (&sym->symbol));
4391 sym->lineno = cache_ptr;
4393 else
4395 cache_ptr->u.offset = dst.l_addr.l_paddr
4396 - bfd_section_vma (abfd, asect);
4397 } /* If no linenumber expect a symbol index */
4399 cache_ptr++;
4400 src++;
4401 counter++;
4403 cache_ptr->line_number = 0;
4406 asect->lineno = lineno_cache;
4407 /* FIXME, free native_lineno here, or use alloca or something. */
4408 return TRUE;
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. */
4415 static bfd_boolean
4416 coff_slurp_symbol_table (abfd)
4417 bfd * abfd;
4419 combined_entry_type *native_symbols;
4420 coff_symbol_type *cached_area;
4421 unsigned int *table_ptr;
4422 bfd_size_type amt;
4423 unsigned int number_of_symbols = 0;
4425 if (obj_symbols (abfd))
4426 return TRUE;
4428 /* Read in the symbol table. */
4429 if ((native_symbols = coff_get_normalized_symtab (abfd)) == NULL)
4430 return FALSE;
4432 /* Allocate enough room for all the symbols in cached form. */
4433 amt = obj_raw_syment_count (abfd);
4434 amt *= sizeof (coff_symbol_type);
4435 cached_area = (coff_symbol_type *) bfd_alloc (abfd, amt);
4436 if (cached_area == NULL)
4437 return FALSE;
4439 amt = obj_raw_syment_count (abfd);
4440 amt *= sizeof (unsigned int);
4441 table_ptr = (unsigned int *) bfd_alloc (abfd, amt);
4443 if (table_ptr == NULL)
4444 return FALSE;
4445 else
4447 coff_symbol_type *dst = cached_area;
4448 unsigned int last_native_index = obj_raw_syment_count (abfd);
4449 unsigned int this_index = 0;
4451 while (this_index < last_native_index)
4453 combined_entry_type *src = native_symbols + this_index;
4454 table_ptr[this_index] = number_of_symbols;
4455 dst->symbol.the_bfd = abfd;
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;
4463 dst->done_lineno = FALSE;
4465 switch (src->u.syment.n_sclass)
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
4474 /* Fall through to next case. */
4475 #endif
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
4487 case C_SYSTEM: /* System Wide variable. */
4488 #endif
4489 #ifdef COFF_WITH_PE
4490 /* In PE, 0x68 (104) denotes a section symbol. */
4491 case C_SECTION:
4492 /* In PE, 0x69 (105) denotes a weak external symbol. */
4493 case C_NT_WEAK:
4494 #endif
4495 switch (coff_classify_symbol (abfd, &src->u.syment))
4497 case COFF_SYMBOL_GLOBAL:
4498 dst->symbol.flags = BSF_EXPORT | BSF_GLOBAL;
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
4507 if (ISFCN ((src->u.syment.n_type)))
4509 /* A function ext does not go at the end of a
4510 file. */
4511 dst->symbol.flags |= BSF_NOT_AT_END | BSF_FUNCTION;
4513 break;
4515 case COFF_SYMBOL_COMMON:
4516 dst->symbol.section = bfd_com_section_ptr;
4517 dst->symbol.value = src->u.syment.n_value;
4518 break;
4520 case COFF_SYMBOL_UNDEFINED:
4521 dst->symbol.section = bfd_und_section_ptr;
4522 dst->symbol.value = 0;
4523 break;
4525 case COFF_SYMBOL_PE_SECTION:
4526 dst->symbol.flags |= BSF_EXPORT | BSF_SECTION_SYM;
4527 dst->symbol.value = 0;
4528 break;
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;
4545 #ifdef RS6000COFF_C
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
4551 #ifdef COFF_WITH_PE
4552 if (src->u.syment.n_sclass == C_NT_WEAK)
4553 dst->symbol.flags |= BSF_WEAK;
4555 if (src->u.syment.n_sclass == C_SECTION
4556 && src->u.syment.n_scnum > 0)
4557 dst->symbol.flags = BSF_LOCAL;
4558 #endif
4559 if (src->u.syment.n_sclass == C_WEAKEXT)
4560 dst->symbol.flags |= BSF_WEAK;
4562 break;
4564 case C_STAT: /* Static. */
4565 #ifdef I960
4566 case C_LEAFSTAT: /* Static leaf procedure. */
4567 #endif
4568 #if defined ARM
4569 case C_THUMBSTAT: /* Thumb static. */
4570 case C_THUMBLABEL: /* Thumb label. */
4571 case C_THUMBSTATFUNC:/* Thumb static function. */
4572 #endif
4573 case C_LABEL: /* Label. */
4574 if (src->u.syment.n_scnum == N_DEBUG)
4575 dst->symbol.flags = BSF_DEBUGGING;
4576 else
4577 dst->symbol.flags = BSF_LOCAL;
4579 /* Base the value as an index from the base of the
4580 section, if there is one. */
4581 if (dst->symbol.section)
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
4592 else
4593 dst->symbol.value = src->u.syment.n_value;
4594 break;
4596 case C_MOS: /* Member of structure. */
4597 case C_EOS: /* End of structure. */
4598 #ifdef NOTDEF /* C_AUTOARG has the same value. */
4599 #ifdef C_GLBLREG
4600 case C_GLBLREG: /* A29k-specific storage class. */
4601 #endif
4602 #endif
4603 case C_REGPARM: /* Register parameter. */
4604 case C_REG: /* register variable. */
4605 /* C_AUTOARG conflictes with TI COFF C_UEXT. */
4606 #if !defined (TIC80COFF) && !defined (TICOFF)
4607 #ifdef C_AUTOARG
4608 case C_AUTOARG: /* 960-specific storage class. */
4609 #endif
4610 #endif
4611 case C_TPDEF: /* Type definition. */
4612 case C_ARG:
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. */
4619 dst->symbol.flags = BSF_DEBUGGING;
4620 dst->symbol.value = (src->u.syment.n_value);
4621 break;
4623 case C_FILE: /* File name. */
4624 case C_STRTAG: /* Structure tag. */
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;
4643 #ifdef RS6000COFF_C
4644 case C_BINCL: /* Beginning of include file. */
4645 case C_EINCL: /* Ending of include file. */
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. */
4651 asection *sec;
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
4657 + sec->lineno_count * bfd_coff_linesz (abfd))
4658 > (file_ptr) src->u.syment.n_value))
4659 break;
4660 if (sec == NULL)
4661 dst->symbol.value = 0;
4662 else
4664 dst->symbol.section = sec;
4665 dst->symbol.value = ((src->u.syment.n_value
4666 - sec->line_filepos)
4667 / bfd_coff_linesz (abfd));
4668 src->fix_line = 1;
4671 break;
4673 case C_BSTAT:
4674 dst->symbol.flags = BSF_DEBUGGING;
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
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. */
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;
4693 if (strcmp (dst->symbol.name, ".bf") != 0)
4695 /* PE uses funny values for .ef and .lf; don't
4696 relocate them. */
4697 dst->symbol.flags = BSF_DEBUGGING;
4699 else
4700 dst->symbol.flags = BSF_DEBUGGING | BSF_DEBUGGING_RELOC;
4701 #else
4702 /* Base the value as an index from the base of the
4703 section. */
4704 dst->symbol.flags = BSF_LOCAL;
4705 dst->symbol.value = (src->u.syment.n_value
4706 - dst->symbol.section->vma);
4707 #endif
4708 break;
4710 case C_STATLAB: /* Static load time label. */
4711 dst->symbol.value = src->u.syment.n_value;
4712 dst->symbol.flags = BSF_GLOBAL;
4713 break;
4715 case C_NULL:
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. */
4723 case C_EXTDEF: /* External definition. */
4724 case C_ULABEL: /* Undefined label. */
4725 case C_USTATIC: /* Undefined static. */
4726 #ifndef COFF_WITH_PE
4727 /* C_LINE in regular coff is 0x68. NT has taken over this storage
4728 class to represent a section symbol. */
4729 case C_LINE: /* line # reformatted as symbol table entry. */
4730 /* NT uses 0x67 for a weak symbol, not C_ALIAS. */
4731 case C_ALIAS: /* Duplicate tag. */
4732 #endif
4733 /* New storage classes for TI COFF. */
4734 #if defined(TIC80COFF) || defined(TICOFF)
4735 case C_UEXT: /* Tentative external definition. */
4736 #endif
4737 case C_EXTLAB: /* External load time label. */
4738 case C_HIDDEN: /* Ext symbol in dmert public lib. */
4739 default:
4740 (*_bfd_error_handler)
4741 (_("%s: Unrecognized storage class %d for %s symbol `%s'"),
4742 bfd_archive_filename (abfd), src->u.syment.n_sclass,
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;
4749 /* BFD_ASSERT(dst->symbol.flags != 0);*/
4751 dst->native = src;
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++;
4761 obj_symbols (abfd) = cached_area;
4762 obj_raw_syments (abfd) = native_symbols;
4764 bfd_get_symcount (abfd) = number_of_symbols;
4765 obj_convert (abfd) = table_ptr;
4766 /* Slurp the line tables for each section too. */
4768 asection *p;
4770 p = abfd->sections;
4771 while (p)
4773 coff_slurp_line_table (abfd, p);
4774 p = p->next;
4778 return TRUE;
4779 } /* coff_slurp_symbol_table() */
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. */
4785 static enum coff_symbol_classification
4786 coff_classify_symbol (abfd, syment)
4787 bfd *abfd;
4788 struct internal_syment *syment;
4790 /* FIXME: This partially duplicates the switch in
4791 coff_slurp_symbol_table. */
4792 switch (syment->n_sclass)
4794 case C_EXT:
4795 case C_WEAKEXT:
4796 #ifdef I960
4797 case C_LEAFEXT:
4798 #endif
4799 #ifdef ARM
4800 case C_THUMBEXT:
4801 case C_THUMBEXTFUNC:
4802 #endif
4803 #ifdef C_SYSTEM
4804 case C_SYSTEM:
4805 #endif
4806 #ifdef COFF_WITH_PE
4807 case C_NT_WEAK:
4808 #endif
4809 if (syment->n_scnum == 0)
4811 if (syment->n_value == 0)
4812 return COFF_SYMBOL_UNDEFINED;
4813 else
4814 return COFF_SYMBOL_COMMON;
4816 return COFF_SYMBOL_GLOBAL;
4818 default:
4819 break;
4822 #ifdef COFF_WITH_PE
4823 if (syment->n_sclass == C_STAT)
4825 if (syment->n_scnum == 0)
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;
4834 #ifdef STRICT_PE_FORMAT
4835 /* This is correct for Microsoft generated objects, but it
4836 breaks gas generated objects. */
4838 if (syment->n_value == 0)
4840 asection *sec;
4841 char buf[SYMNMLEN + 1];
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;
4850 #endif
4852 return COFF_SYMBOL_LOCAL;
4855 if (syment->n_sclass == C_SECTION)
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;
4865 #endif /* COFF_WITH_PE */
4867 /* If it is not a global symbol, we presume it is a local symbol. */
4869 if (syment->n_scnum == 0)
4871 char buf[SYMNMLEN + 1];
4873 (*_bfd_error_handler)
4874 (_("warning: %s: local symbol `%s' has no section"),
4875 bfd_archive_filename (abfd),
4876 _bfd_coff_internal_syment_name (abfd, syment, buf));
4879 return COFF_SYMBOL_LOCAL;
4883 SUBSUBSECTION
4884 Reading relocations
4886 Coff relocations are easily transformed into the internal BFD form
4887 (@code{arelent}).
4889 Reading a coff relocation table is done in the following stages:
4891 o Read the entire coff relocation table into memory.
4893 o Process each relocation in turn; first swap it from the
4894 external to the internal form.
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.
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.
4910 #ifndef CALC_ADDEND
4911 #define CALC_ADDEND(abfd, ptr, reloc, cache_ptr) \
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; \
4928 #endif
4930 static bfd_boolean
4931 coff_slurp_reloc_table (abfd, asect, symbols)
4932 bfd * abfd;
4933 sec_ptr asect;
4934 asymbol ** symbols;
4936 RELOC *native_relocs;
4937 arelent *reloc_cache;
4938 arelent *cache_ptr;
4939 unsigned int idx;
4940 bfd_size_type amt;
4942 if (asect->relocation)
4943 return TRUE;
4944 if (asect->reloc_count == 0)
4945 return TRUE;
4946 if (asect->flags & SEC_CONSTRUCTOR)
4947 return TRUE;
4948 if (!coff_slurp_symbol_table (abfd))
4949 return FALSE;
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);
4955 if (reloc_cache == NULL)
4956 return FALSE;
4958 for (idx = 0; idx < asect->reloc_count; idx++)
4960 struct internal_reloc dst;
4961 struct external_reloc *src;
4962 #ifndef RELOC_PROCESSING
4963 asymbol *ptr;
4964 #endif
4966 cache_ptr = reloc_cache + idx;
4967 src = native_relocs + idx;
4969 coff_swap_reloc_in (abfd, src, &dst);
4971 #ifdef RELOC_PROCESSING
4972 RELOC_PROCESSING (cache_ptr, &dst, symbols, abfd, asect);
4973 #else
4974 cache_ptr->address = dst.r_vaddr;
4976 if (dst.r_symndx != -1)
4978 if (dst.r_symndx < 0 || dst.r_symndx >= obj_conv_table_size (abfd))
4980 (*_bfd_error_handler)
4981 (_("%s: warning: illegal symbol index %ld in relocs"),
4982 bfd_archive_filename (abfd), dst.r_symndx);
4983 cache_ptr->sym_ptr_ptr = bfd_abs_section_ptr->symbol_ptr_ptr;
4984 ptr = NULL;
4986 else
4988 cache_ptr->sym_ptr_ptr = (symbols
4989 + obj_convert (abfd)[dst.r_symndx]);
4990 ptr = *(cache_ptr->sym_ptr_ptr);
4993 else
4995 cache_ptr->sym_ptr_ptr = bfd_abs_section_ptr->symbol_ptr_ptr;
4996 ptr = NULL;
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.
5004 Note that symbols which used to be common must be left alone. */
5006 /* Calculate any reloc addend by looking at the symbol. */
5007 CALC_ADDEND (abfd, ptr, dst, cache_ptr);
5009 cache_ptr->address -= asect->vma;
5010 /* !! cache_ptr->section = (asection *) NULL;*/
5012 /* Fill in the cache_ptr->howto field from dst.r_type. */
5013 RTYPE2HOWTO (cache_ptr, &dst);
5014 #endif /* RELOC_PROCESSING */
5016 if (cache_ptr->howto == NULL)
5018 (*_bfd_error_handler)
5019 (_("%s: illegal relocation type %d at address 0x%lx"),
5020 bfd_archive_filename (abfd), dst.r_type, (long) dst.r_vaddr);
5021 bfd_set_error (bfd_error_bad_value);
5022 return FALSE;
5026 asect->relocation = reloc_cache;
5027 return TRUE;
5030 #ifndef coff_rtype_to_howto
5031 #ifdef RTYPE2HOWTO
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. */
5039 static 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 *));
5044 /*ARGSUSED*/
5045 static reloc_howto_type *
5046 coff_rtype_to_howto (abfd, sec, rel, h, sym, addendp)
5047 bfd *abfd ATTRIBUTE_UNUSED;
5048 asection *sec ATTRIBUTE_UNUSED;
5049 struct internal_reloc *rel;
5050 struct coff_link_hash_entry *h ATTRIBUTE_UNUSED;
5051 struct internal_syment *sym ATTRIBUTE_UNUSED;
5052 bfd_vma *addendp ATTRIBUTE_UNUSED;
5054 arelent genrel;
5056 RTYPE2HOWTO (&genrel, rel);
5057 return genrel.howto;
5060 #else /* ! defined (RTYPE2HOWTO) */
5062 #define coff_rtype_to_howto NULL
5064 #endif /* ! defined (RTYPE2HOWTO) */
5065 #endif /* ! defined (coff_rtype_to_howto) */
5067 /* This is stupid. This function should be a boolean predicate. */
5068 static long
5069 coff_canonicalize_reloc (abfd, section, relptr, symbols)
5070 bfd * abfd;
5071 sec_ptr section;
5072 arelent ** relptr;
5073 asymbol ** symbols;
5075 arelent *tblptr = section->relocation;
5076 unsigned int count = 0;
5078 if (section->flags & SEC_CONSTRUCTOR)
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. */
5083 arelent_chain *chain = section->constructor_chain;
5085 for (count = 0; count < section->reloc_count; count++)
5087 *relptr++ = &chain->relent;
5088 chain = chain->next;
5091 else
5093 if (! coff_slurp_reloc_table (abfd, section, symbols))
5094 return -1;
5096 tblptr = section->relocation;
5098 for (; count++ < section->reloc_count;)
5099 *relptr++ = tblptr++;
5101 *relptr = 0;
5102 return section->reloc_count;
5105 #ifdef GNU960
5106 file_ptr
5107 coff_sym_filepos (abfd)
5108 bfd *abfd;
5110 return obj_sym_filepos (abfd);
5112 #endif
5114 #ifndef coff_reloc16_estimate
5115 #define coff_reloc16_estimate dummy_reloc16_estimate
5117 static int dummy_reloc16_estimate
5118 PARAMS ((bfd *, asection *, arelent *, unsigned int,
5119 struct bfd_link_info *));
5121 static int
5122 dummy_reloc16_estimate (abfd, input_section, reloc, shrink, link_info)
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;
5129 abort ();
5130 return 0;
5133 #endif
5135 #ifndef coff_reloc16_extra_cases
5137 #define coff_reloc16_extra_cases dummy_reloc16_extra_cases
5139 /* This works even if abort is not declared in any header file. */
5141 static void dummy_reloc16_extra_cases
5142 PARAMS ((bfd *, struct bfd_link_info *, struct bfd_link_order *, arelent *,
5143 bfd_byte *, unsigned int *, unsigned int *));
5145 static void
5146 dummy_reloc16_extra_cases (abfd, link_info, link_order, reloc, data, src_ptr,
5147 dst_ptr)
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;
5156 abort ();
5158 #endif
5160 #ifndef coff_bfd_link_hash_table_free
5161 #define coff_bfd_link_hash_table_free _bfd_generic_link_hash_table_free
5162 #endif
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) */
5187 #define coff_bfd_link_just_syms _bfd_generic_link_just_syms
5188 #define coff_bfd_link_split_section _bfd_generic_link_split_section
5190 #ifndef coff_start_final_link
5191 #define coff_start_final_link NULL
5192 #endif
5194 #ifndef coff_adjust_symndx
5195 #define coff_adjust_symndx NULL
5196 #endif
5198 #ifndef coff_link_add_one_symbol
5199 #define coff_link_add_one_symbol _bfd_generic_link_add_one_symbol
5200 #endif
5202 #ifndef coff_link_output_has_begun
5204 static bfd_boolean coff_link_output_has_begun
5205 PARAMS ((bfd *, struct coff_final_link_info *));
5207 static bfd_boolean
5208 coff_link_output_has_begun (abfd, info)
5209 bfd * abfd;
5210 struct coff_final_link_info * info ATTRIBUTE_UNUSED;
5212 return abfd->output_has_begun;
5214 #endif
5216 #ifndef coff_final_link_postscript
5218 static bfd_boolean coff_final_link_postscript
5219 PARAMS ((bfd *, struct coff_final_link_info *));
5221 static bfd_boolean
5222 coff_final_link_postscript (abfd, pfinfo)
5223 bfd * abfd ATTRIBUTE_UNUSED;
5224 struct coff_final_link_info * pfinfo ATTRIBUTE_UNUSED;
5226 return TRUE;
5228 #endif
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
5273 static const bfd_coff_backend_data bfd_coff_std_swap_table =
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,
5280 FILHSZ, AOUTSZ, SCNHSZ, SYMESZ, AUXESZ, RELSZ, LINESZ, FILNMLEN,
5281 #ifdef COFF_LONG_FILENAMES
5282 TRUE,
5283 #else
5284 FALSE,
5285 #endif
5286 #ifdef COFF_LONG_SECTION_NAMES
5287 TRUE,
5288 #else
5289 FALSE,
5290 #endif
5291 COFF_DEFAULT_SECTION_ALIGNMENT_POWER,
5292 #ifdef COFF_FORCE_SYMBOLS_IN_STRINGS
5293 TRUE,
5294 #else
5295 FALSE,
5296 #endif
5297 #ifdef COFF_DEBUG_STRING_WIDE_PREFIX
5299 #else
5301 #endif
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,
5307 coff_classify_symbol, coff_compute_section_file_positions,
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
5313 #ifndef coff_close_and_cleanup
5314 #define coff_close_and_cleanup _bfd_generic_close_and_cleanup
5315 #endif
5317 #ifndef coff_bfd_free_cached_info
5318 #define coff_bfd_free_cached_info _bfd_generic_bfd_free_cached_info
5319 #endif
5321 #ifndef coff_get_section_contents
5322 #define coff_get_section_contents _bfd_generic_get_section_contents
5323 #endif
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
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
5333 #ifndef coff_bfd_copy_private_bfd_data
5334 #define coff_bfd_copy_private_bfd_data _bfd_generic_bfd_copy_private_bfd_data
5335 #endif
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
5341 #ifndef coff_bfd_set_private_flags
5342 #define coff_bfd_set_private_flags _bfd_generic_bfd_set_private_flags
5343 #endif
5345 #ifndef coff_bfd_print_private_bfd_data
5346 #define coff_bfd_print_private_bfd_data _bfd_generic_bfd_print_private_bfd_data
5347 #endif
5349 #ifndef coff_bfd_is_local_label_name
5350 #define coff_bfd_is_local_label_name _bfd_coff_is_local_label_name
5351 #endif
5353 #ifndef coff_read_minisymbols
5354 #define coff_read_minisymbols _bfd_generic_read_minisymbols
5355 #endif
5357 #ifndef coff_minisymbol_to_symbol
5358 #define coff_minisymbol_to_symbol _bfd_generic_minisymbol_to_symbol
5359 #endif
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
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
5372 #ifndef coff_bfd_relax_section
5373 #define coff_bfd_relax_section bfd_generic_relax_section
5374 #endif
5376 #ifndef coff_bfd_gc_sections
5377 #define coff_bfd_gc_sections bfd_generic_gc_sections
5378 #endif
5380 #ifndef coff_bfd_merge_sections
5381 #define coff_bfd_merge_sections bfd_generic_merge_sections
5382 #endif
5384 #ifndef coff_bfd_discard_group
5385 #define coff_bfd_discard_group bfd_generic_discard_group
5386 #endif
5388 #define CREATE_BIG_COFF_TARGET_VEC(VAR, NAME, EXTRA_O_FLAGS, EXTRA_S_FLAGS, UNDER, ALTERNATIVE) \
5389 const bfd_target VAR = \
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 */ \
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, \
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, \
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 }, \
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), \
5433 ALTERNATIVE, \
5435 COFF_SWAP_TABLE \
5438 #define CREATE_LITTLE_COFF_TARGET_VEC(VAR, NAME, EXTRA_O_FLAGS, EXTRA_S_FLAGS, UNDER, ALTERNATIVE) \
5439 const bfd_target VAR = \
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 */ \
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 }, \
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), \
5481 ALTERNATIVE, \
5483 COFF_SWAP_TABLE \