* common.cc (Symbol_table::do_allocate_commons_list): For incremental
[binutils.git] / bfd / coffcode.h
blobe71aadd30430bd903d652505e288b6a5555c68aa
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, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011
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 3 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., 51 Franklin Street - Fifth Floor, Boston,
22 MA 02110-1301, USA. */
24 /* Most of this hacked by Steve Chamberlain,
25 sac@cygnus.com. */
27 SECTION
28 coff backends
30 BFD supports a number of different flavours of coff format.
31 The major differences between formats are the sizes and
32 alignments of fields in structures on disk, and the occasional
33 extra field.
35 Coff in all its varieties is implemented with a few common
36 files and a number of implementation specific files. For
37 example, The 88k bcs coff format is implemented in the file
38 @file{coff-m88k.c}. This file @code{#include}s
39 @file{coff/m88k.h} which defines the external structure of the
40 coff format for the 88k, and @file{coff/internal.h} which
41 defines the internal structure. @file{coff-m88k.c} also
42 defines the relocations used by the 88k format
43 @xref{Relocations}.
45 The Intel i960 processor version of coff is implemented in
46 @file{coff-i960.c}. This file has the same structure as
47 @file{coff-m88k.c}, except that it includes @file{coff/i960.h}
48 rather than @file{coff-m88k.h}.
50 SUBSECTION
51 Porting to a new version of coff
53 The recommended method is to select from the existing
54 implementations the version of coff which is most like the one
55 you want to use. For example, we'll say that i386 coff is
56 the one you select, and that your coff flavour is called foo.
57 Copy @file{i386coff.c} to @file{foocoff.c}, copy
58 @file{../include/coff/i386.h} to @file{../include/coff/foo.h},
59 and add the lines to @file{targets.c} and @file{Makefile.in}
60 so that your new back end is used. Alter the shapes of the
61 structures in @file{../include/coff/foo.h} so that they match
62 what you need. You will probably also have to add
63 @code{#ifdef}s to the code in @file{coff/internal.h} and
64 @file{coffcode.h} if your version of coff is too wild.
66 You can verify that your new BFD backend works quite simply by
67 building @file{objdump} from the @file{binutils} directory,
68 and making sure that its version of what's going on and your
69 host system's idea (assuming it has the pretty standard coff
70 dump utility, usually called @code{att-dump} or just
71 @code{dump}) are the same. Then clean up your code, and send
72 what you've done to Cygnus. Then your stuff will be in the
73 next release, and you won't have to keep integrating it.
75 SUBSECTION
76 How the coff backend works
78 SUBSUBSECTION
79 File layout
81 The Coff backend is split into generic routines that are
82 applicable to any Coff target and routines that are specific
83 to a particular target. The target-specific routines are
84 further split into ones which are basically the same for all
85 Coff targets except that they use the external symbol format
86 or use different values for certain constants.
88 The generic routines are in @file{coffgen.c}. These routines
89 work for any Coff target. They use some hooks into the target
90 specific code; the hooks are in a @code{bfd_coff_backend_data}
91 structure, one of which exists for each target.
93 The essentially similar target-specific routines are in
94 @file{coffcode.h}. This header file includes executable C code.
95 The various Coff targets first include the appropriate Coff
96 header file, make any special defines that are needed, and
97 then include @file{coffcode.h}.
99 Some of the Coff targets then also have additional routines in
100 the target source file itself.
102 For example, @file{coff-i960.c} includes
103 @file{coff/internal.h} and @file{coff/i960.h}. It then
104 defines a few constants, such as @code{I960}, and includes
105 @file{coffcode.h}. Since the i960 has complex relocation
106 types, @file{coff-i960.c} also includes some code to
107 manipulate the i960 relocs. This code is not in
108 @file{coffcode.h} because it would not be used by any other
109 target.
111 SUBSUBSECTION
112 Coff long section names
114 In the standard Coff object format, section names are limited to
115 the eight bytes available in the @code{s_name} field of the
116 @code{SCNHDR} section header structure. The format requires the
117 field to be NUL-padded, but not necessarily NUL-terminated, so
118 the longest section names permitted are a full eight characters.
120 The Microsoft PE variants of the Coff object file format add
121 an extension to support the use of long section names. This
122 extension is defined in section 4 of the Microsoft PE/COFF
123 specification (rev 8.1). If a section name is too long to fit
124 into the section header's @code{s_name} field, it is instead
125 placed into the string table, and the @code{s_name} field is
126 filled with a slash ("/") followed by the ASCII decimal
127 representation of the offset of the full name relative to the
128 string table base.
130 Note that this implies that the extension can only be used in object
131 files, as executables do not contain a string table. The standard
132 specifies that long section names from objects emitted into executable
133 images are to be truncated.
135 However, as a GNU extension, BFD can generate executable images
136 that contain a string table and long section names. This
137 would appear to be technically valid, as the standard only says
138 that Coff debugging information is deprecated, not forbidden,
139 and in practice it works, although some tools that parse PE files
140 expecting the MS standard format may become confused; @file{PEview} is
141 one known example.
143 The functionality is supported in BFD by code implemented under
144 the control of the macro @code{COFF_LONG_SECTION_NAMES}. If not
145 defined, the format does not support long section names in any way.
146 If defined, it is used to initialise a flag,
147 @code{_bfd_coff_long_section_names}, and a hook function pointer,
148 @code{_bfd_coff_set_long_section_names}, in the Coff backend data
149 structure. The flag controls the generation of long section names
150 in output BFDs at runtime; if it is false, as it will be by default
151 when generating an executable image, long section names are truncated;
152 if true, the long section names extension is employed. The hook
153 points to a function that allows the value of the flag to be altered
154 at runtime, on formats that support long section names at all; on
155 other formats it points to a stub that returns an error indication.
157 With input BFDs, the flag is set according to whether any long section
158 names are detected while reading the section headers. For a completely
159 new BFD, the flag is set to the default for the target format. This
160 information can be used by a client of the BFD library when deciding
161 what output format to generate, and means that a BFD that is opened
162 for read and subsequently converted to a writeable BFD and modified
163 in-place will retain whatever format it had on input.
165 If @code{COFF_LONG_SECTION_NAMES} is simply defined (blank), or is
166 defined to the value "1", then long section names are enabled by
167 default; if it is defined to the value zero, they are disabled by
168 default (but still accepted in input BFDs). The header @file{coffcode.h}
169 defines a macro, @code{COFF_DEFAULT_LONG_SECTION_NAMES}, which is
170 used in the backends to initialise the backend data structure fields
171 appropriately; see the comments for further detail.
173 SUBSUBSECTION
174 Bit twiddling
176 Each flavour of coff supported in BFD has its own header file
177 describing the external layout of the structures. There is also
178 an internal description of the coff layout, in
179 @file{coff/internal.h}. A major function of the
180 coff backend is swapping the bytes and twiddling the bits to
181 translate the external form of the structures into the normal
182 internal form. This is all performed in the
183 @code{bfd_swap}_@i{thing}_@i{direction} routines. Some
184 elements are different sizes between different versions of
185 coff; it is the duty of the coff version specific include file
186 to override the definitions of various packing routines in
187 @file{coffcode.h}. E.g., the size of line number entry in coff is
188 sometimes 16 bits, and sometimes 32 bits. @code{#define}ing
189 @code{PUT_LNSZ_LNNO} and @code{GET_LNSZ_LNNO} will select the
190 correct one. No doubt, some day someone will find a version of
191 coff which has a varying field size not catered to at the
192 moment. To port BFD, that person will have to add more @code{#defines}.
193 Three of the bit twiddling routines are exported to
194 @code{gdb}; @code{coff_swap_aux_in}, @code{coff_swap_sym_in}
195 and @code{coff_swap_lineno_in}. @code{GDB} reads the symbol
196 table on its own, but uses BFD to fix things up. More of the
197 bit twiddlers are exported for @code{gas};
198 @code{coff_swap_aux_out}, @code{coff_swap_sym_out},
199 @code{coff_swap_lineno_out}, @code{coff_swap_reloc_out},
200 @code{coff_swap_filehdr_out}, @code{coff_swap_aouthdr_out},
201 @code{coff_swap_scnhdr_out}. @code{Gas} currently keeps track
202 of all the symbol table and reloc drudgery itself, thereby
203 saving the internal BFD overhead, but uses BFD to swap things
204 on the way out, making cross ports much safer. Doing so also
205 allows BFD (and thus the linker) to use the same header files
206 as @code{gas}, which makes one avenue to disaster disappear.
208 SUBSUBSECTION
209 Symbol reading
211 The simple canonical form for symbols used by BFD is not rich
212 enough to keep all the information available in a coff symbol
213 table. The back end gets around this problem by keeping the original
214 symbol table around, "behind the scenes".
216 When a symbol table is requested (through a call to
217 @code{bfd_canonicalize_symtab}), a request gets through to
218 @code{coff_get_normalized_symtab}. This reads the symbol table from
219 the coff file and swaps all the structures inside into the
220 internal form. It also fixes up all the pointers in the table
221 (represented in the file by offsets from the first symbol in
222 the table) into physical pointers to elements in the new
223 internal table. This involves some work since the meanings of
224 fields change depending upon context: a field that is a
225 pointer to another structure in the symbol table at one moment
226 may be the size in bytes of a structure at the next. Another
227 pass is made over the table. All symbols which mark file names
228 (<<C_FILE>> symbols) are modified so that the internal
229 string points to the value in the auxent (the real filename)
230 rather than the normal text associated with the symbol
231 (@code{".file"}).
233 At this time the symbol names are moved around. Coff stores
234 all symbols less than nine characters long physically
235 within the symbol table; longer strings are kept at the end of
236 the file in the string table. This pass moves all strings
237 into memory and replaces them with pointers to the strings.
239 The symbol table is massaged once again, this time to create
240 the canonical table used by the BFD application. Each symbol
241 is inspected in turn, and a decision made (using the
242 @code{sclass} field) about the various flags to set in the
243 @code{asymbol}. @xref{Symbols}. The generated canonical table
244 shares strings with the hidden internal symbol table.
246 Any linenumbers are read from the coff file too, and attached
247 to the symbols which own the functions the linenumbers belong to.
249 SUBSUBSECTION
250 Symbol writing
252 Writing a symbol to a coff file which didn't come from a coff
253 file will lose any debugging information. The @code{asymbol}
254 structure remembers the BFD from which the symbol was taken, and on
255 output the back end makes sure that the same destination target as
256 source target is present.
258 When the symbols have come from a coff file then all the
259 debugging information is preserved.
261 Symbol tables are provided for writing to the back end in a
262 vector of pointers to pointers. This allows applications like
263 the linker to accumulate and output large symbol tables
264 without having to do too much byte copying.
266 This function runs through the provided symbol table and
267 patches each symbol marked as a file place holder
268 (@code{C_FILE}) to point to the next file place holder in the
269 list. It also marks each @code{offset} field in the list with
270 the offset from the first symbol of the current symbol.
272 Another function of this procedure is to turn the canonical
273 value form of BFD into the form used by coff. Internally, BFD
274 expects symbol values to be offsets from a section base; so a
275 symbol physically at 0x120, but in a section starting at
276 0x100, would have the value 0x20. Coff expects symbols to
277 contain their final value, so symbols have their values
278 changed at this point to reflect their sum with their owning
279 section. This transformation uses the
280 <<output_section>> field of the @code{asymbol}'s
281 @code{asection} @xref{Sections}.
283 o <<coff_mangle_symbols>>
285 This routine runs though the provided symbol table and uses
286 the offsets generated by the previous pass and the pointers
287 generated when the symbol table was read in to create the
288 structured hierarchy required by coff. It changes each pointer
289 to a symbol into the index into the symbol table of the asymbol.
291 o <<coff_write_symbols>>
293 This routine runs through the symbol table and patches up the
294 symbols from their internal form into the coff way, calls the
295 bit twiddlers, and writes out the table to the file.
300 INTERNAL_DEFINITION
301 coff_symbol_type
303 DESCRIPTION
304 The hidden information for an <<asymbol>> is described in a
305 <<combined_entry_type>>:
307 CODE_FRAGMENT
309 .typedef struct coff_ptr_struct
311 . {* Remembers the offset from the first symbol in the file for
312 . this symbol. Generated by coff_renumber_symbols. *}
313 . unsigned int offset;
315 . {* Should the value of this symbol be renumbered. Used for
316 . XCOFF C_BSTAT symbols. Set by coff_slurp_symbol_table. *}
317 . unsigned int fix_value : 1;
319 . {* Should the tag field of this symbol be renumbered.
320 . Created by coff_pointerize_aux. *}
321 . unsigned int fix_tag : 1;
323 . {* Should the endidx field of this symbol be renumbered.
324 . Created by coff_pointerize_aux. *}
325 . unsigned int fix_end : 1;
327 . {* Should the x_csect.x_scnlen field be renumbered.
328 . Created by coff_pointerize_aux. *}
329 . unsigned int fix_scnlen : 1;
331 . {* Fix up an XCOFF C_BINCL/C_EINCL symbol. The value is the
332 . index into the line number entries. Set by coff_slurp_symbol_table. *}
333 . unsigned int fix_line : 1;
335 . {* The container for the symbol structure as read and translated
336 . from the file. *}
337 . union
339 . union internal_auxent auxent;
340 . struct internal_syment syment;
341 . } u;
342 .} combined_entry_type;
345 .{* Each canonical asymbol really looks like this: *}
347 .typedef struct coff_symbol_struct
349 . {* The actual symbol which the rest of BFD works with *}
350 . asymbol symbol;
352 . {* A pointer to the hidden information for this symbol *}
353 . combined_entry_type *native;
355 . {* A pointer to the linenumber information for this symbol *}
356 . struct lineno_cache_entry *lineno;
358 . {* Have the line numbers been relocated yet ? *}
359 . bfd_boolean done_lineno;
360 .} coff_symbol_type;
364 #include "libiberty.h"
366 #ifdef COFF_WITH_PE
367 #include "peicode.h"
368 #else
369 #include "coffswap.h"
370 #endif
372 #define STRING_SIZE_SIZE 4
374 #define DOT_DEBUG ".debug"
375 #define GNU_LINKONCE_WI ".gnu.linkonce.wi."
376 #define GNU_LINKONCE_WT ".gnu.linkonce.wt."
377 #define DOT_RELOC ".reloc"
379 #if defined (COFF_LONG_SECTION_NAMES)
380 /* Needed to expand the inputs to BLANKOR1TOODD. */
381 #define COFFLONGSECTIONCATHELPER(x,y) x ## y
382 /* If the input macro Y is blank or '1', return an odd number; if it is
383 '0', return an even number. Result undefined in all other cases. */
384 #define BLANKOR1TOODD(y) COFFLONGSECTIONCATHELPER(1,y)
385 /* Defined to numerical 0 or 1 according to whether generation of long
386 section names is disabled or enabled by default. */
387 #define COFF_ENABLE_LONG_SECTION_NAMES (BLANKOR1TOODD(COFF_LONG_SECTION_NAMES) & 1)
388 /* Where long section names are supported, we allow them to be enabled
389 and disabled at runtime, so select an appropriate hook function for
390 _bfd_coff_set_long_section_names. */
391 #define COFF_LONG_SECTION_NAMES_SETTER bfd_coff_set_long_section_names_allowed
392 #else /* !defined (COFF_LONG_SECTION_NAMES) */
393 /* If long section names are not supported, this stub disallows any
394 attempt to enable them at run-time. */
395 #define COFF_LONG_SECTION_NAMES_SETTER bfd_coff_set_long_section_names_disallowed
396 #endif /* defined (COFF_LONG_SECTION_NAMES) */
398 /* Define a macro that can be used to initialise both the fields relating
399 to long section names in the backend data struct simultaneously. */
400 #if COFF_ENABLE_LONG_SECTION_NAMES
401 #define COFF_DEFAULT_LONG_SECTION_NAMES (TRUE), COFF_LONG_SECTION_NAMES_SETTER
402 #else /* !COFF_ENABLE_LONG_SECTION_NAMES */
403 #define COFF_DEFAULT_LONG_SECTION_NAMES (FALSE), COFF_LONG_SECTION_NAMES_SETTER
404 #endif /* COFF_ENABLE_LONG_SECTION_NAMES */
406 #if defined (COFF_LONG_SECTION_NAMES)
407 static bfd_boolean bfd_coff_set_long_section_names_allowed
408 (bfd *, int);
409 #else /* !defined (COFF_LONG_SECTION_NAMES) */
410 static bfd_boolean bfd_coff_set_long_section_names_disallowed
411 (bfd *, int);
412 #endif /* defined (COFF_LONG_SECTION_NAMES) */
413 static long sec_to_styp_flags
414 (const char *, flagword);
415 static bfd_boolean styp_to_sec_flags
416 (bfd *, void *, const char *, asection *, flagword *);
417 static bfd_boolean coff_bad_format_hook
418 (bfd *, void *);
419 static void coff_set_custom_section_alignment
420 (bfd *, asection *, const struct coff_section_alignment_entry *,
421 const unsigned int);
422 static bfd_boolean coff_new_section_hook
423 (bfd *, asection *);
424 static bfd_boolean coff_set_arch_mach_hook
425 (bfd *, void *);
426 static bfd_boolean coff_write_relocs
427 (bfd *, int);
428 static bfd_boolean coff_set_flags
429 (bfd *, unsigned int *, unsigned short *);
430 static bfd_boolean coff_set_arch_mach
431 (bfd *, enum bfd_architecture, unsigned long) ATTRIBUTE_UNUSED;
432 static bfd_boolean coff_compute_section_file_positions
433 (bfd *);
434 static bfd_boolean coff_write_object_contents
435 (bfd *) ATTRIBUTE_UNUSED;
436 static bfd_boolean coff_set_section_contents
437 (bfd *, asection *, const void *, file_ptr, bfd_size_type);
438 static void * buy_and_read
439 (bfd *, file_ptr, bfd_size_type);
440 static bfd_boolean coff_slurp_line_table
441 (bfd *, asection *);
442 static bfd_boolean coff_slurp_symbol_table
443 (bfd *);
444 static enum coff_symbol_classification coff_classify_symbol
445 (bfd *, struct internal_syment *);
446 static bfd_boolean coff_slurp_reloc_table
447 (bfd *, asection *, asymbol **);
448 static long coff_canonicalize_reloc
449 (bfd *, asection *, arelent **, asymbol **);
450 #ifndef coff_mkobject_hook
451 static void * coff_mkobject_hook
452 (bfd *, void *, void *);
453 #endif
454 #ifdef COFF_WITH_PE
455 static flagword handle_COMDAT
456 (bfd *, flagword, void *, const char *, asection *);
457 #endif
458 #ifdef COFF_IMAGE_WITH_PE
459 static bfd_boolean coff_read_word
460 (bfd *, unsigned int *);
461 static unsigned int coff_compute_checksum
462 (bfd *);
463 static bfd_boolean coff_apply_checksum
464 (bfd *);
465 #endif
466 #ifdef TICOFF
467 static bfd_boolean ticoff0_bad_format_hook
468 (bfd *, void * );
469 static bfd_boolean ticoff1_bad_format_hook
470 (bfd *, void * );
471 #endif
473 /* void warning(); */
475 #if defined (COFF_LONG_SECTION_NAMES)
476 static bfd_boolean
477 bfd_coff_set_long_section_names_allowed (bfd *abfd, int enable)
479 coff_backend_info (abfd)->_bfd_coff_long_section_names = enable;
480 return TRUE;
482 #else /* !defined (COFF_LONG_SECTION_NAMES) */
483 static bfd_boolean
484 bfd_coff_set_long_section_names_disallowed (bfd *abfd, int enable)
486 (void) abfd;
487 (void) enable;
488 return FALSE;
490 #endif /* defined (COFF_LONG_SECTION_NAMES) */
492 /* Return a word with STYP_* (scnhdr.s_flags) flags set to represent
493 the incoming SEC_* flags. The inverse of this function is
494 styp_to_sec_flags(). NOTE: If you add to/change this routine, you
495 should probably mirror the changes in styp_to_sec_flags(). */
497 #ifndef COFF_WITH_PE
499 /* Macros for setting debugging flags. */
501 #ifdef STYP_DEBUG
502 #define STYP_XCOFF_DEBUG STYP_DEBUG
503 #else
504 #define STYP_XCOFF_DEBUG STYP_INFO
505 #endif
507 #ifdef COFF_ALIGN_IN_S_FLAGS
508 #define STYP_DEBUG_INFO STYP_DSECT
509 #else
510 #define STYP_DEBUG_INFO STYP_INFO
511 #endif
513 static long
514 sec_to_styp_flags (const char *sec_name, flagword sec_flags)
516 long styp_flags = 0;
518 if (!strcmp (sec_name, _TEXT))
520 styp_flags = STYP_TEXT;
522 else if (!strcmp (sec_name, _DATA))
524 styp_flags = STYP_DATA;
526 else if (!strcmp (sec_name, _BSS))
528 styp_flags = STYP_BSS;
529 #ifdef _COMMENT
531 else if (!strcmp (sec_name, _COMMENT))
533 styp_flags = STYP_INFO;
534 #endif /* _COMMENT */
535 #ifdef _LIB
537 else if (!strcmp (sec_name, _LIB))
539 styp_flags = STYP_LIB;
540 #endif /* _LIB */
541 #ifdef _LIT
543 else if (!strcmp (sec_name, _LIT))
545 styp_flags = STYP_LIT;
546 #endif /* _LIT */
548 else if (CONST_STRNEQ (sec_name, DOT_DEBUG))
550 /* Handle the XCOFF debug section and DWARF2 debug sections. */
551 if (!sec_name[6])
552 styp_flags = STYP_XCOFF_DEBUG;
553 else
554 styp_flags = STYP_DEBUG_INFO;
556 else if (CONST_STRNEQ (sec_name, ".stab"))
558 styp_flags = STYP_DEBUG_INFO;
560 #ifdef COFF_LONG_SECTION_NAMES
561 else if (CONST_STRNEQ (sec_name, GNU_LINKONCE_WI)
562 || CONST_STRNEQ (sec_name, GNU_LINKONCE_WT))
564 styp_flags = STYP_DEBUG_INFO;
566 #endif
567 #ifdef RS6000COFF_C
568 else if (!strcmp (sec_name, _PAD))
570 styp_flags = STYP_PAD;
572 else if (!strcmp (sec_name, _LOADER))
574 styp_flags = STYP_LOADER;
576 else if (!strcmp (sec_name, _EXCEPT))
578 styp_flags = STYP_EXCEPT;
580 else if (!strcmp (sec_name, _TYPCHK))
582 styp_flags = STYP_TYPCHK;
584 else if (sec_flags & SEC_DEBUGGING)
586 int i;
588 for (i = 0; i < XCOFF_DWSECT_NBR_NAMES; i++)
589 if (!strcmp (sec_name, xcoff_dwsect_names[i].name))
591 styp_flags = STYP_DWARF | xcoff_dwsect_names[i].flag;
592 break;
595 #endif
596 /* Try and figure out what it should be */
597 else if (sec_flags & SEC_CODE)
599 styp_flags = STYP_TEXT;
601 else if (sec_flags & SEC_DATA)
603 styp_flags = STYP_DATA;
605 else if (sec_flags & SEC_READONLY)
607 #ifdef STYP_LIT /* 29k readonly text/data section */
608 styp_flags = STYP_LIT;
609 #else
610 styp_flags = STYP_TEXT;
611 #endif /* STYP_LIT */
613 else if (sec_flags & SEC_LOAD)
615 styp_flags = STYP_TEXT;
617 else if (sec_flags & SEC_ALLOC)
619 styp_flags = STYP_BSS;
622 #ifdef STYP_CLINK
623 if (sec_flags & SEC_TIC54X_CLINK)
624 styp_flags |= STYP_CLINK;
625 #endif
627 #ifdef STYP_BLOCK
628 if (sec_flags & SEC_TIC54X_BLOCK)
629 styp_flags |= STYP_BLOCK;
630 #endif
632 #ifdef STYP_NOLOAD
633 if ((sec_flags & (SEC_NEVER_LOAD | SEC_COFF_SHARED_LIBRARY)) != 0)
634 styp_flags |= STYP_NOLOAD;
635 #endif
637 return styp_flags;
640 #else /* COFF_WITH_PE */
642 /* The PE version; see above for the general comments. The non-PE
643 case seems to be more guessing, and breaks PE format; specifically,
644 .rdata is readonly, but it sure ain't text. Really, all this
645 should be set up properly in gas (or whatever assembler is in use),
646 and honor whatever objcopy/strip, etc. sent us as input. */
648 static long
649 sec_to_styp_flags (const char *sec_name, flagword sec_flags)
651 long styp_flags = 0;
652 bfd_boolean is_dbg = FALSE;
654 if (CONST_STRNEQ (sec_name, DOT_DEBUG)
655 #ifdef COFF_LONG_SECTION_NAMES
656 || CONST_STRNEQ (sec_name, GNU_LINKONCE_WI)
657 || CONST_STRNEQ (sec_name, GNU_LINKONCE_WT)
658 #endif
659 || CONST_STRNEQ (sec_name, ".stab"))
660 is_dbg = TRUE;
662 /* caution: there are at least three groups of symbols that have
663 very similar bits and meanings: IMAGE_SCN*, SEC_*, and STYP_*.
664 SEC_* are the BFD internal flags, used for generic BFD
665 information. STYP_* are the COFF section flags which appear in
666 COFF files. IMAGE_SCN_* are the PE section flags which appear in
667 PE files. The STYP_* flags and the IMAGE_SCN_* flags overlap,
668 but there are more IMAGE_SCN_* flags. */
670 /* FIXME: There is no gas syntax to specify the debug section flag. */
671 if (is_dbg)
673 sec_flags &= (SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD);
674 sec_flags |= SEC_DEBUGGING | SEC_READONLY;
677 /* skip LOAD */
678 /* READONLY later */
679 /* skip RELOC */
680 if ((sec_flags & SEC_CODE) != 0)
681 styp_flags |= IMAGE_SCN_CNT_CODE;
682 if ((sec_flags & (SEC_DATA | SEC_DEBUGGING)) != 0)
683 styp_flags |= IMAGE_SCN_CNT_INITIALIZED_DATA;
684 if ((sec_flags & SEC_ALLOC) != 0 && (sec_flags & SEC_LOAD) == 0)
685 styp_flags |= IMAGE_SCN_CNT_UNINITIALIZED_DATA; /* ==STYP_BSS */
686 /* skip ROM */
687 /* skip constRUCTOR */
688 /* skip CONTENTS */
689 if ((sec_flags & SEC_IS_COMMON) != 0)
690 styp_flags |= IMAGE_SCN_LNK_COMDAT;
691 if ((sec_flags & SEC_DEBUGGING) != 0)
692 styp_flags |= IMAGE_SCN_MEM_DISCARDABLE;
693 if ((sec_flags & SEC_EXCLUDE) != 0 && !is_dbg)
694 styp_flags |= IMAGE_SCN_LNK_REMOVE;
695 if ((sec_flags & SEC_NEVER_LOAD) != 0 && !is_dbg)
696 styp_flags |= IMAGE_SCN_LNK_REMOVE;
697 /* skip IN_MEMORY */
698 /* skip SORT */
699 if (sec_flags & SEC_LINK_ONCE)
700 styp_flags |= IMAGE_SCN_LNK_COMDAT;
701 /* skip LINK_DUPLICATES */
702 /* skip LINKER_CREATED */
704 if ((sec_flags & SEC_COFF_NOREAD) == 0)
705 styp_flags |= IMAGE_SCN_MEM_READ; /* Invert NOREAD for read. */
706 if ((sec_flags & SEC_READONLY) == 0)
707 styp_flags |= IMAGE_SCN_MEM_WRITE; /* Invert READONLY for write. */
708 if (sec_flags & SEC_CODE)
709 styp_flags |= IMAGE_SCN_MEM_EXECUTE; /* CODE->EXECUTE. */
710 if (sec_flags & SEC_COFF_SHARED)
711 styp_flags |= IMAGE_SCN_MEM_SHARED; /* Shared remains meaningful. */
713 return styp_flags;
716 #endif /* COFF_WITH_PE */
718 /* Return a word with SEC_* flags set to represent the incoming STYP_*
719 flags (from scnhdr.s_flags). The inverse of this function is
720 sec_to_styp_flags(). NOTE: If you add to/change this routine, you
721 should probably mirror the changes in sec_to_styp_flags(). */
723 #ifndef COFF_WITH_PE
725 static bfd_boolean
726 styp_to_sec_flags (bfd *abfd ATTRIBUTE_UNUSED,
727 void * hdr,
728 const char *name,
729 asection *section ATTRIBUTE_UNUSED,
730 flagword *flags_ptr)
732 struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
733 long styp_flags = internal_s->s_flags;
734 flagword sec_flags = 0;
736 #ifdef STYP_BLOCK
737 if (styp_flags & STYP_BLOCK)
738 sec_flags |= SEC_TIC54X_BLOCK;
739 #endif
741 #ifdef STYP_CLINK
742 if (styp_flags & STYP_CLINK)
743 sec_flags |= SEC_TIC54X_CLINK;
744 #endif
746 #ifdef STYP_NOLOAD
747 if (styp_flags & STYP_NOLOAD)
748 sec_flags |= SEC_NEVER_LOAD;
749 #endif /* STYP_NOLOAD */
751 /* For 386 COFF, at least, an unloadable text or data section is
752 actually a shared library section. */
753 if (styp_flags & STYP_TEXT)
755 if (sec_flags & SEC_NEVER_LOAD)
756 sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
757 else
758 sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
760 else if (styp_flags & STYP_DATA)
762 if (sec_flags & SEC_NEVER_LOAD)
763 sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
764 else
765 sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
767 else if (styp_flags & STYP_BSS)
769 #ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
770 if (sec_flags & SEC_NEVER_LOAD)
771 sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
772 else
773 #endif
774 sec_flags |= SEC_ALLOC;
776 else if (styp_flags & STYP_INFO)
778 /* We mark these as SEC_DEBUGGING, but only if COFF_PAGE_SIZE is
779 defined. coff_compute_section_file_positions uses
780 COFF_PAGE_SIZE to ensure that the low order bits of the
781 section VMA and the file offset match. If we don't know
782 COFF_PAGE_SIZE, we can't ensure the correct correspondence,
783 and demand page loading of the file will fail. */
784 #if defined (COFF_PAGE_SIZE) && !defined (COFF_ALIGN_IN_S_FLAGS)
785 sec_flags |= SEC_DEBUGGING;
786 #endif
788 else if (styp_flags & STYP_PAD)
789 sec_flags = 0;
790 #ifdef RS6000COFF_C
791 else if (styp_flags & STYP_DWARF)
792 sec_flags |= SEC_DEBUGGING;
793 #endif
794 else if (strcmp (name, _TEXT) == 0)
796 if (sec_flags & SEC_NEVER_LOAD)
797 sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
798 else
799 sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
801 else if (strcmp (name, _DATA) == 0)
803 if (sec_flags & SEC_NEVER_LOAD)
804 sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
805 else
806 sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
808 else if (strcmp (name, _BSS) == 0)
810 #ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
811 if (sec_flags & SEC_NEVER_LOAD)
812 sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
813 else
814 #endif
815 sec_flags |= SEC_ALLOC;
817 else if (CONST_STRNEQ (name, DOT_DEBUG)
818 #ifdef _COMMENT
819 || strcmp (name, _COMMENT) == 0
820 #endif
821 #ifdef COFF_LONG_SECTION_NAMES
822 || CONST_STRNEQ (name, GNU_LINKONCE_WI)
823 || CONST_STRNEQ (name, GNU_LINKONCE_WT)
824 #endif
825 || CONST_STRNEQ (name, ".stab"))
827 #ifdef COFF_PAGE_SIZE
828 sec_flags |= SEC_DEBUGGING;
829 #endif
831 #ifdef _LIB
832 else if (strcmp (name, _LIB) == 0)
834 #endif
835 #ifdef _LIT
836 else if (strcmp (name, _LIT) == 0)
837 sec_flags = SEC_LOAD | SEC_ALLOC | SEC_READONLY;
838 #endif
839 else
840 sec_flags |= SEC_ALLOC | SEC_LOAD;
842 #ifdef STYP_LIT /* A29k readonly text/data section type. */
843 if ((styp_flags & STYP_LIT) == STYP_LIT)
844 sec_flags = (SEC_LOAD | SEC_ALLOC | SEC_READONLY);
845 #endif /* STYP_LIT */
847 #ifdef STYP_OTHER_LOAD /* Other loaded sections. */
848 if (styp_flags & STYP_OTHER_LOAD)
849 sec_flags = (SEC_LOAD | SEC_ALLOC);
850 #endif /* STYP_SDATA */
852 #if defined (COFF_LONG_SECTION_NAMES) && defined (COFF_SUPPORT_GNU_LINKONCE)
853 /* As a GNU extension, if the name begins with .gnu.linkonce, we
854 only link a single copy of the section. This is used to support
855 g++. g++ will emit each template expansion in its own section.
856 The symbols will be defined as weak, so that multiple definitions
857 are permitted. The GNU linker extension is to actually discard
858 all but one of the sections. */
859 if (CONST_STRNEQ (name, ".gnu.linkonce"))
860 sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
861 #endif
863 if (flags_ptr == NULL)
864 return FALSE;
866 * flags_ptr = sec_flags;
867 return TRUE;
870 #else /* COFF_WITH_PE */
872 static flagword
873 handle_COMDAT (bfd * abfd,
874 flagword sec_flags,
875 void * hdr,
876 const char *name,
877 asection *section)
879 struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
880 bfd_byte *esymstart, *esym, *esymend;
881 int seen_state = 0;
882 char *target_name = NULL;
884 sec_flags |= SEC_LINK_ONCE;
886 /* Unfortunately, the PE format stores essential information in
887 the symbol table, of all places. We need to extract that
888 information now, so that objdump and the linker will know how
889 to handle the section without worrying about the symbols. We
890 can't call slurp_symtab, because the linker doesn't want the
891 swapped symbols. */
893 /* COMDAT sections are special. The first symbol is the section
894 symbol, which tells what kind of COMDAT section it is. The
895 second symbol is the "comdat symbol" - the one with the
896 unique name. GNU uses the section symbol for the unique
897 name; MS uses ".text" for every comdat section. Sigh. - DJ */
899 /* This is not mirrored in sec_to_styp_flags(), but there
900 doesn't seem to be a need to, either, and it would at best be
901 rather messy. */
903 if (! _bfd_coff_get_external_symbols (abfd))
904 return sec_flags;
906 esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
907 esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
909 while (esym < esymend)
911 struct internal_syment isym;
912 char buf[SYMNMLEN + 1];
913 const char *symname;
915 bfd_coff_swap_sym_in (abfd, esym, & isym);
917 if (sizeof (internal_s->s_name) > SYMNMLEN)
919 /* This case implies that the matching
920 symbol name will be in the string table. */
921 abort ();
924 if (isym.n_scnum == section->target_index)
926 /* According to the MSVC documentation, the first
927 TWO entries with the section # are both of
928 interest to us. The first one is the "section
929 symbol" (section name). The second is the comdat
930 symbol name. Here, we've found the first
931 qualifying entry; we distinguish it from the
932 second with a state flag.
934 In the case of gas-generated (at least until that
935 is fixed) .o files, it isn't necessarily the
936 second one. It may be some other later symbol.
938 Since gas also doesn't follow MS conventions and
939 emits the section similar to .text$<name>, where
940 <something> is the name we're looking for, we
941 distinguish the two as follows:
943 If the section name is simply a section name (no
944 $) we presume it's MS-generated, and look at
945 precisely the second symbol for the comdat name.
946 If the section name has a $, we assume it's
947 gas-generated, and look for <something> (whatever
948 follows the $) as the comdat symbol. */
950 /* All 3 branches use this. */
951 symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
953 if (symname == NULL)
954 abort ();
956 switch (seen_state)
958 case 0:
960 /* The first time we've seen the symbol. */
961 union internal_auxent aux;
963 /* If it isn't the stuff we're expecting, die;
964 The MS documentation is vague, but it
965 appears that the second entry serves BOTH
966 as the comdat symbol and the defining
967 symbol record (either C_STAT or C_EXT,
968 possibly with an aux entry with debug
969 information if it's a function.) It
970 appears the only way to find the second one
971 is to count. (On Intel, they appear to be
972 adjacent, but on Alpha, they have been
973 found separated.)
975 Here, we think we've found the first one,
976 but there's some checking we can do to be
977 sure. */
979 if (! ((isym.n_sclass == C_STAT
980 || isym.n_sclass == C_EXT)
981 && BTYPE (isym.n_type) == T_NULL
982 && isym.n_value == 0))
983 abort ();
985 /* FIXME LATER: MSVC generates section names
986 like .text for comdats. Gas generates
987 names like .text$foo__Fv (in the case of a
988 function). See comment above for more. */
990 if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
991 _bfd_error_handler (_("%B: warning: COMDAT symbol '%s' does not match section name '%s'"),
992 abfd, symname, name);
994 seen_state = 1;
996 /* This is the section symbol. */
997 bfd_coff_swap_aux_in (abfd, (esym + bfd_coff_symesz (abfd)),
998 isym.n_type, isym.n_sclass,
999 0, isym.n_numaux, & aux);
1001 target_name = strchr (name, '$');
1002 if (target_name != NULL)
1004 /* Gas mode. */
1005 seen_state = 2;
1006 /* Skip the `$'. */
1007 target_name += 1;
1010 /* FIXME: Microsoft uses NODUPLICATES and
1011 ASSOCIATIVE, but gnu uses ANY and
1012 SAME_SIZE. Unfortunately, gnu doesn't do
1013 the comdat symbols right. So, until we can
1014 fix it to do the right thing, we are
1015 temporarily disabling comdats for the MS
1016 types (they're used in DLLs and C++, but we
1017 don't support *their* C++ libraries anyway
1018 - DJ. */
1020 /* Cygwin does not follow the MS style, and
1021 uses ANY and SAME_SIZE where NODUPLICATES
1022 and ASSOCIATIVE should be used. For
1023 Interix, we just do the right thing up
1024 front. */
1026 switch (aux.x_scn.x_comdat)
1028 case IMAGE_COMDAT_SELECT_NODUPLICATES:
1029 #ifdef STRICT_PE_FORMAT
1030 sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1031 #else
1032 sec_flags &= ~SEC_LINK_ONCE;
1033 #endif
1034 break;
1036 case IMAGE_COMDAT_SELECT_ANY:
1037 sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1038 break;
1040 case IMAGE_COMDAT_SELECT_SAME_SIZE:
1041 sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1042 break;
1044 case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1045 /* Not yet fully implemented ??? */
1046 sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1047 break;
1049 /* debug$S gets this case; other
1050 implications ??? */
1052 /* There may be no symbol... we'll search
1053 the whole table... Is this the right
1054 place to play this game? Or should we do
1055 it when reading it in. */
1056 case IMAGE_COMDAT_SELECT_ASSOCIATIVE:
1057 #ifdef STRICT_PE_FORMAT
1058 /* FIXME: This is not currently implemented. */
1059 sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1060 #else
1061 sec_flags &= ~SEC_LINK_ONCE;
1062 #endif
1063 break;
1065 default: /* 0 means "no symbol" */
1066 /* debug$F gets this case; other
1067 implications ??? */
1068 sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1069 break;
1072 break;
1074 case 2:
1075 /* Gas mode: the first matching on partial name. */
1077 #ifndef TARGET_UNDERSCORE
1078 #define TARGET_UNDERSCORE 0
1079 #endif
1080 /* Is this the name we're looking for ? */
1081 if (strcmp (target_name,
1082 symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1084 /* Not the name we're looking for */
1085 esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd);
1086 continue;
1088 /* Fall through. */
1089 case 1:
1090 /* MSVC mode: the lexically second symbol (or
1091 drop through from the above). */
1093 char *newname;
1094 bfd_size_type amt;
1096 /* This must the second symbol with the
1097 section #. It is the actual symbol name.
1098 Intel puts the two adjacent, but Alpha (at
1099 least) spreads them out. */
1101 amt = sizeof (struct coff_comdat_info);
1102 coff_section_data (abfd, section)->comdat
1103 = (struct coff_comdat_info *) bfd_alloc (abfd, amt);
1104 if (coff_section_data (abfd, section)->comdat == NULL)
1105 abort ();
1107 coff_section_data (abfd, section)->comdat->symbol =
1108 (esym - esymstart) / bfd_coff_symesz (abfd);
1110 amt = strlen (symname) + 1;
1111 newname = (char *) bfd_alloc (abfd, amt);
1112 if (newname == NULL)
1113 abort ();
1115 strcpy (newname, symname);
1116 coff_section_data (abfd, section)->comdat->name
1117 = newname;
1120 goto breakloop;
1124 esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd);
1127 breakloop:
1128 return sec_flags;
1132 /* The PE version; see above for the general comments.
1134 Since to set the SEC_LINK_ONCE and associated flags, we have to
1135 look at the symbol table anyway, we return the symbol table index
1136 of the symbol being used as the COMDAT symbol. This is admittedly
1137 ugly, but there's really nowhere else that we have access to the
1138 required information. FIXME: Is the COMDAT symbol index used for
1139 any purpose other than objdump? */
1141 static bfd_boolean
1142 styp_to_sec_flags (bfd *abfd,
1143 void * hdr,
1144 const char *name,
1145 asection *section,
1146 flagword *flags_ptr)
1148 struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1149 long styp_flags = internal_s->s_flags;
1150 flagword sec_flags;
1151 bfd_boolean result = TRUE;
1152 bfd_boolean is_dbg = FALSE;
1154 if (CONST_STRNEQ (name, DOT_DEBUG)
1155 #ifdef COFF_LONG_SECTION_NAMES
1156 || CONST_STRNEQ (name, GNU_LINKONCE_WI)
1157 || CONST_STRNEQ (name, GNU_LINKONCE_WT)
1158 #endif
1159 || CONST_STRNEQ (name, ".stab"))
1160 is_dbg = TRUE;
1161 /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified. */
1162 sec_flags = SEC_READONLY;
1164 /* If section disallows read, then set the NOREAD flag. */
1165 if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1166 sec_flags |= SEC_COFF_NOREAD;
1168 /* Process each flag bit in styp_flags in turn. */
1169 while (styp_flags)
1171 long flag = styp_flags & - styp_flags;
1172 char * unhandled = NULL;
1174 styp_flags &= ~ flag;
1176 /* We infer from the distinct read/write/execute bits the settings
1177 of some of the bfd flags; the actual values, should we need them,
1178 are also in pei_section_data (abfd, section)->pe_flags. */
1180 switch (flag)
1182 case STYP_DSECT:
1183 unhandled = "STYP_DSECT";
1184 break;
1185 case STYP_GROUP:
1186 unhandled = "STYP_GROUP";
1187 break;
1188 case STYP_COPY:
1189 unhandled = "STYP_COPY";
1190 break;
1191 case STYP_OVER:
1192 unhandled = "STYP_OVER";
1193 break;
1194 #ifdef SEC_NEVER_LOAD
1195 case STYP_NOLOAD:
1196 sec_flags |= SEC_NEVER_LOAD;
1197 break;
1198 #endif
1199 case IMAGE_SCN_MEM_READ:
1200 sec_flags &= ~SEC_COFF_NOREAD;
1201 break;
1202 case IMAGE_SCN_TYPE_NO_PAD:
1203 /* Skip. */
1204 break;
1205 case IMAGE_SCN_LNK_OTHER:
1206 unhandled = "IMAGE_SCN_LNK_OTHER";
1207 break;
1208 case IMAGE_SCN_MEM_NOT_CACHED:
1209 unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1210 break;
1211 case IMAGE_SCN_MEM_NOT_PAGED:
1212 /* Generate a warning message rather using the 'unhandled'
1213 variable as this will allow some .sys files generate by
1214 other toolchains to be processed. See bugzilla issue 196. */
1215 _bfd_error_handler (_("%B: Warning: Ignoring section flag IMAGE_SCN_MEM_NOT_PAGED in section %s"),
1216 abfd, name);
1217 break;
1218 case IMAGE_SCN_MEM_EXECUTE:
1219 sec_flags |= SEC_CODE;
1220 break;
1221 case IMAGE_SCN_MEM_WRITE:
1222 sec_flags &= ~ SEC_READONLY;
1223 break;
1224 case IMAGE_SCN_MEM_DISCARDABLE:
1225 /* The MS PE spec says that debug sections are DISCARDABLE,
1226 but the presence of a DISCARDABLE flag does not necessarily
1227 mean that a given section contains debug information. Thus
1228 we only set the SEC_DEBUGGING flag on sections that we
1229 recognise as containing debug information. */
1230 if (is_dbg
1231 #ifdef _COMMENT
1232 || strcmp (name, _COMMENT) == 0
1233 #endif
1236 sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1238 break;
1239 case IMAGE_SCN_MEM_SHARED:
1240 sec_flags |= SEC_COFF_SHARED;
1241 break;
1242 case IMAGE_SCN_LNK_REMOVE:
1243 if (!is_dbg)
1244 sec_flags |= SEC_EXCLUDE;
1245 break;
1246 case IMAGE_SCN_CNT_CODE:
1247 sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248 break;
1249 case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250 if (is_dbg)
1251 sec_flags |= SEC_DEBUGGING;
1252 else
1253 sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254 break;
1255 case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256 sec_flags |= SEC_ALLOC;
1257 break;
1258 case IMAGE_SCN_LNK_INFO:
1259 /* We mark these as SEC_DEBUGGING, but only if COFF_PAGE_SIZE is
1260 defined. coff_compute_section_file_positions uses
1261 COFF_PAGE_SIZE to ensure that the low order bits of the
1262 section VMA and the file offset match. If we don't know
1263 COFF_PAGE_SIZE, we can't ensure the correct correspondence,
1264 and demand page loading of the file will fail. */
1265 #ifdef COFF_PAGE_SIZE
1266 sec_flags |= SEC_DEBUGGING;
1267 #endif
1268 break;
1269 case IMAGE_SCN_LNK_COMDAT:
1270 /* COMDAT gets very special treatment. */
1271 sec_flags = handle_COMDAT (abfd, sec_flags, hdr, name, section);
1272 break;
1273 default:
1274 /* Silently ignore for now. */
1275 break;
1278 /* If the section flag was not handled, report it here. */
1279 if (unhandled != NULL)
1281 (*_bfd_error_handler)
1282 (_("%B (%s): Section flag %s (0x%x) ignored"),
1283 abfd, name, unhandled, flag);
1284 result = FALSE;
1288 #if defined (COFF_LONG_SECTION_NAMES) && defined (COFF_SUPPORT_GNU_LINKONCE)
1289 /* As a GNU extension, if the name begins with .gnu.linkonce, we
1290 only link a single copy of the section. This is used to support
1291 g++. g++ will emit each template expansion in its own section.
1292 The symbols will be defined as weak, so that multiple definitions
1293 are permitted. The GNU linker extension is to actually discard
1294 all but one of the sections. */
1295 if (CONST_STRNEQ (name, ".gnu.linkonce"))
1296 sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
1297 #endif
1299 if (flags_ptr)
1300 * flags_ptr = sec_flags;
1302 return result;
1305 #endif /* COFF_WITH_PE */
1307 #define get_index(symbol) ((symbol)->udata.i)
1310 INTERNAL_DEFINITION
1311 bfd_coff_backend_data
1313 CODE_FRAGMENT
1315 .{* COFF symbol classifications. *}
1317 .enum coff_symbol_classification
1319 . {* Global symbol. *}
1320 . COFF_SYMBOL_GLOBAL,
1321 . {* Common symbol. *}
1322 . COFF_SYMBOL_COMMON,
1323 . {* Undefined symbol. *}
1324 . COFF_SYMBOL_UNDEFINED,
1325 . {* Local symbol. *}
1326 . COFF_SYMBOL_LOCAL,
1327 . {* PE section symbol. *}
1328 . COFF_SYMBOL_PE_SECTION
1331 Special entry points for gdb to swap in coff symbol table parts:
1332 .typedef struct
1334 . void (*_bfd_coff_swap_aux_in)
1335 . (bfd *, void *, int, int, int, int, void *);
1337 . void (*_bfd_coff_swap_sym_in)
1338 . (bfd *, void *, void *);
1340 . void (*_bfd_coff_swap_lineno_in)
1341 . (bfd *, void *, void *);
1343 . unsigned int (*_bfd_coff_swap_aux_out)
1344 . (bfd *, void *, int, int, int, int, void *);
1346 . unsigned int (*_bfd_coff_swap_sym_out)
1347 . (bfd *, void *, void *);
1349 . unsigned int (*_bfd_coff_swap_lineno_out)
1350 . (bfd *, void *, void *);
1352 . unsigned int (*_bfd_coff_swap_reloc_out)
1353 . (bfd *, void *, void *);
1355 . unsigned int (*_bfd_coff_swap_filehdr_out)
1356 . (bfd *, void *, void *);
1358 . unsigned int (*_bfd_coff_swap_aouthdr_out)
1359 . (bfd *, void *, void *);
1361 . unsigned int (*_bfd_coff_swap_scnhdr_out)
1362 . (bfd *, void *, void *);
1364 . unsigned int _bfd_filhsz;
1365 . unsigned int _bfd_aoutsz;
1366 . unsigned int _bfd_scnhsz;
1367 . unsigned int _bfd_symesz;
1368 . unsigned int _bfd_auxesz;
1369 . unsigned int _bfd_relsz;
1370 . unsigned int _bfd_linesz;
1371 . unsigned int _bfd_filnmlen;
1372 . bfd_boolean _bfd_coff_long_filenames;
1374 . bfd_boolean _bfd_coff_long_section_names;
1375 . bfd_boolean (*_bfd_coff_set_long_section_names)
1376 . (bfd *, int);
1378 . unsigned int _bfd_coff_default_section_alignment_power;
1379 . bfd_boolean _bfd_coff_force_symnames_in_strings;
1380 . unsigned int _bfd_coff_debug_string_prefix_length;
1382 . void (*_bfd_coff_swap_filehdr_in)
1383 . (bfd *, void *, void *);
1385 . void (*_bfd_coff_swap_aouthdr_in)
1386 . (bfd *, void *, void *);
1388 . void (*_bfd_coff_swap_scnhdr_in)
1389 . (bfd *, void *, void *);
1391 . void (*_bfd_coff_swap_reloc_in)
1392 . (bfd *abfd, void *, void *);
1394 . bfd_boolean (*_bfd_coff_bad_format_hook)
1395 . (bfd *, void *);
1397 . bfd_boolean (*_bfd_coff_set_arch_mach_hook)
1398 . (bfd *, void *);
1400 . void * (*_bfd_coff_mkobject_hook)
1401 . (bfd *, void *, void *);
1403 . bfd_boolean (*_bfd_styp_to_sec_flags_hook)
1404 . (bfd *, void *, const char *, asection *, flagword *);
1406 . void (*_bfd_set_alignment_hook)
1407 . (bfd *, asection *, void *);
1409 . bfd_boolean (*_bfd_coff_slurp_symbol_table)
1410 . (bfd *);
1412 . bfd_boolean (*_bfd_coff_symname_in_debug)
1413 . (bfd *, struct internal_syment *);
1415 . bfd_boolean (*_bfd_coff_pointerize_aux_hook)
1416 . (bfd *, combined_entry_type *, combined_entry_type *,
1417 . unsigned int, combined_entry_type *);
1419 . bfd_boolean (*_bfd_coff_print_aux)
1420 . (bfd *, FILE *, combined_entry_type *, combined_entry_type *,
1421 . combined_entry_type *, unsigned int);
1423 . void (*_bfd_coff_reloc16_extra_cases)
1424 . (bfd *, struct bfd_link_info *, struct bfd_link_order *, arelent *,
1425 . bfd_byte *, unsigned int *, unsigned int *);
1427 . int (*_bfd_coff_reloc16_estimate)
1428 . (bfd *, asection *, arelent *, unsigned int,
1429 . struct bfd_link_info *);
1431 . enum coff_symbol_classification (*_bfd_coff_classify_symbol)
1432 . (bfd *, struct internal_syment *);
1434 . bfd_boolean (*_bfd_coff_compute_section_file_positions)
1435 . (bfd *);
1437 . bfd_boolean (*_bfd_coff_start_final_link)
1438 . (bfd *, struct bfd_link_info *);
1440 . bfd_boolean (*_bfd_coff_relocate_section)
1441 . (bfd *, struct bfd_link_info *, bfd *, asection *, bfd_byte *,
1442 . struct internal_reloc *, struct internal_syment *, asection **);
1444 . reloc_howto_type *(*_bfd_coff_rtype_to_howto)
1445 . (bfd *, asection *, struct internal_reloc *,
1446 . struct coff_link_hash_entry *, struct internal_syment *,
1447 . bfd_vma *);
1449 . bfd_boolean (*_bfd_coff_adjust_symndx)
1450 . (bfd *, struct bfd_link_info *, bfd *, asection *,
1451 . struct internal_reloc *, bfd_boolean *);
1453 . bfd_boolean (*_bfd_coff_link_add_one_symbol)
1454 . (struct bfd_link_info *, bfd *, const char *, flagword,
1455 . asection *, bfd_vma, const char *, bfd_boolean, bfd_boolean,
1456 . struct bfd_link_hash_entry **);
1458 . bfd_boolean (*_bfd_coff_link_output_has_begun)
1459 . (bfd *, struct coff_final_link_info *);
1461 . bfd_boolean (*_bfd_coff_final_link_postscript)
1462 . (bfd *, struct coff_final_link_info *);
1464 . bfd_boolean (*_bfd_coff_print_pdata)
1465 . (bfd *, void *);
1467 .} bfd_coff_backend_data;
1469 .#define coff_backend_info(abfd) \
1470 . ((bfd_coff_backend_data *) (abfd)->xvec->backend_data)
1472 .#define bfd_coff_swap_aux_in(a,e,t,c,ind,num,i) \
1473 . ((coff_backend_info (a)->_bfd_coff_swap_aux_in) (a,e,t,c,ind,num,i))
1475 .#define bfd_coff_swap_sym_in(a,e,i) \
1476 . ((coff_backend_info (a)->_bfd_coff_swap_sym_in) (a,e,i))
1478 .#define bfd_coff_swap_lineno_in(a,e,i) \
1479 . ((coff_backend_info ( a)->_bfd_coff_swap_lineno_in) (a,e,i))
1481 .#define bfd_coff_swap_reloc_out(abfd, i, o) \
1482 . ((coff_backend_info (abfd)->_bfd_coff_swap_reloc_out) (abfd, i, o))
1484 .#define bfd_coff_swap_lineno_out(abfd, i, o) \
1485 . ((coff_backend_info (abfd)->_bfd_coff_swap_lineno_out) (abfd, i, o))
1487 .#define bfd_coff_swap_aux_out(a,i,t,c,ind,num,o) \
1488 . ((coff_backend_info (a)->_bfd_coff_swap_aux_out) (a,i,t,c,ind,num,o))
1490 .#define bfd_coff_swap_sym_out(abfd, i,o) \
1491 . ((coff_backend_info (abfd)->_bfd_coff_swap_sym_out) (abfd, i, o))
1493 .#define bfd_coff_swap_scnhdr_out(abfd, i,o) \
1494 . ((coff_backend_info (abfd)->_bfd_coff_swap_scnhdr_out) (abfd, i, o))
1496 .#define bfd_coff_swap_filehdr_out(abfd, i,o) \
1497 . ((coff_backend_info (abfd)->_bfd_coff_swap_filehdr_out) (abfd, i, o))
1499 .#define bfd_coff_swap_aouthdr_out(abfd, i,o) \
1500 . ((coff_backend_info (abfd)->_bfd_coff_swap_aouthdr_out) (abfd, i, o))
1502 .#define bfd_coff_filhsz(abfd) (coff_backend_info (abfd)->_bfd_filhsz)
1503 .#define bfd_coff_aoutsz(abfd) (coff_backend_info (abfd)->_bfd_aoutsz)
1504 .#define bfd_coff_scnhsz(abfd) (coff_backend_info (abfd)->_bfd_scnhsz)
1505 .#define bfd_coff_symesz(abfd) (coff_backend_info (abfd)->_bfd_symesz)
1506 .#define bfd_coff_auxesz(abfd) (coff_backend_info (abfd)->_bfd_auxesz)
1507 .#define bfd_coff_relsz(abfd) (coff_backend_info (abfd)->_bfd_relsz)
1508 .#define bfd_coff_linesz(abfd) (coff_backend_info (abfd)->_bfd_linesz)
1509 .#define bfd_coff_filnmlen(abfd) (coff_backend_info (abfd)->_bfd_filnmlen)
1510 .#define bfd_coff_long_filenames(abfd) \
1511 . (coff_backend_info (abfd)->_bfd_coff_long_filenames)
1512 .#define bfd_coff_long_section_names(abfd) \
1513 . (coff_backend_info (abfd)->_bfd_coff_long_section_names)
1514 .#define bfd_coff_set_long_section_names(abfd, enable) \
1515 . ((coff_backend_info (abfd)->_bfd_coff_set_long_section_names) (abfd, enable))
1516 .#define bfd_coff_default_section_alignment_power(abfd) \
1517 . (coff_backend_info (abfd)->_bfd_coff_default_section_alignment_power)
1518 .#define bfd_coff_swap_filehdr_in(abfd, i,o) \
1519 . ((coff_backend_info (abfd)->_bfd_coff_swap_filehdr_in) (abfd, i, o))
1521 .#define bfd_coff_swap_aouthdr_in(abfd, i,o) \
1522 . ((coff_backend_info (abfd)->_bfd_coff_swap_aouthdr_in) (abfd, i, o))
1524 .#define bfd_coff_swap_scnhdr_in(abfd, i,o) \
1525 . ((coff_backend_info (abfd)->_bfd_coff_swap_scnhdr_in) (abfd, i, o))
1527 .#define bfd_coff_swap_reloc_in(abfd, i, o) \
1528 . ((coff_backend_info (abfd)->_bfd_coff_swap_reloc_in) (abfd, i, o))
1530 .#define bfd_coff_bad_format_hook(abfd, filehdr) \
1531 . ((coff_backend_info (abfd)->_bfd_coff_bad_format_hook) (abfd, filehdr))
1533 .#define bfd_coff_set_arch_mach_hook(abfd, filehdr)\
1534 . ((coff_backend_info (abfd)->_bfd_coff_set_arch_mach_hook) (abfd, filehdr))
1535 .#define bfd_coff_mkobject_hook(abfd, filehdr, aouthdr)\
1536 . ((coff_backend_info (abfd)->_bfd_coff_mkobject_hook)\
1537 . (abfd, filehdr, aouthdr))
1539 .#define bfd_coff_styp_to_sec_flags_hook(abfd, scnhdr, name, section, flags_ptr)\
1540 . ((coff_backend_info (abfd)->_bfd_styp_to_sec_flags_hook)\
1541 . (abfd, scnhdr, name, section, flags_ptr))
1543 .#define bfd_coff_set_alignment_hook(abfd, sec, scnhdr)\
1544 . ((coff_backend_info (abfd)->_bfd_set_alignment_hook) (abfd, sec, scnhdr))
1546 .#define bfd_coff_slurp_symbol_table(abfd)\
1547 . ((coff_backend_info (abfd)->_bfd_coff_slurp_symbol_table) (abfd))
1549 .#define bfd_coff_symname_in_debug(abfd, sym)\
1550 . ((coff_backend_info (abfd)->_bfd_coff_symname_in_debug) (abfd, sym))
1552 .#define bfd_coff_force_symnames_in_strings(abfd)\
1553 . (coff_backend_info (abfd)->_bfd_coff_force_symnames_in_strings)
1555 .#define bfd_coff_debug_string_prefix_length(abfd)\
1556 . (coff_backend_info (abfd)->_bfd_coff_debug_string_prefix_length)
1558 .#define bfd_coff_print_aux(abfd, file, base, symbol, aux, indaux)\
1559 . ((coff_backend_info (abfd)->_bfd_coff_print_aux)\
1560 . (abfd, file, base, symbol, aux, indaux))
1562 .#define bfd_coff_reloc16_extra_cases(abfd, link_info, link_order,\
1563 . reloc, data, src_ptr, dst_ptr)\
1564 . ((coff_backend_info (abfd)->_bfd_coff_reloc16_extra_cases)\
1565 . (abfd, link_info, link_order, reloc, data, src_ptr, dst_ptr))
1567 .#define bfd_coff_reloc16_estimate(abfd, section, reloc, shrink, link_info)\
1568 . ((coff_backend_info (abfd)->_bfd_coff_reloc16_estimate)\
1569 . (abfd, section, reloc, shrink, link_info))
1571 .#define bfd_coff_classify_symbol(abfd, sym)\
1572 . ((coff_backend_info (abfd)->_bfd_coff_classify_symbol)\
1573 . (abfd, sym))
1575 .#define bfd_coff_compute_section_file_positions(abfd)\
1576 . ((coff_backend_info (abfd)->_bfd_coff_compute_section_file_positions)\
1577 . (abfd))
1579 .#define bfd_coff_start_final_link(obfd, info)\
1580 . ((coff_backend_info (obfd)->_bfd_coff_start_final_link)\
1581 . (obfd, info))
1582 .#define bfd_coff_relocate_section(obfd,info,ibfd,o,con,rel,isyms,secs)\
1583 . ((coff_backend_info (ibfd)->_bfd_coff_relocate_section)\
1584 . (obfd, info, ibfd, o, con, rel, isyms, secs))
1585 .#define bfd_coff_rtype_to_howto(abfd, sec, rel, h, sym, addendp)\
1586 . ((coff_backend_info (abfd)->_bfd_coff_rtype_to_howto)\
1587 . (abfd, sec, rel, h, sym, addendp))
1588 .#define bfd_coff_adjust_symndx(obfd, info, ibfd, sec, rel, adjustedp)\
1589 . ((coff_backend_info (abfd)->_bfd_coff_adjust_symndx)\
1590 . (obfd, info, ibfd, sec, rel, adjustedp))
1591 .#define bfd_coff_link_add_one_symbol(info, abfd, name, flags, section,\
1592 . value, string, cp, coll, hashp)\
1593 . ((coff_backend_info (abfd)->_bfd_coff_link_add_one_symbol)\
1594 . (info, abfd, name, flags, section, value, string, cp, coll, hashp))
1596 .#define bfd_coff_link_output_has_begun(a,p) \
1597 . ((coff_backend_info (a)->_bfd_coff_link_output_has_begun) (a, p))
1598 .#define bfd_coff_final_link_postscript(a,p) \
1599 . ((coff_backend_info (a)->_bfd_coff_final_link_postscript) (a, p))
1601 .#define bfd_coff_have_print_pdata(a) \
1602 . (coff_backend_info (a)->_bfd_coff_print_pdata)
1603 .#define bfd_coff_print_pdata(a,p) \
1604 . ((coff_backend_info (a)->_bfd_coff_print_pdata) (a, p))
1606 .{* Macro: Returns true if the bfd is a PE executable as opposed to a
1607 . PE object file. *}
1608 .#define bfd_pei_p(abfd) \
1609 . (CONST_STRNEQ ((abfd)->xvec->name, "pei-"))
1612 /* See whether the magic number matches. */
1614 static bfd_boolean
1615 coff_bad_format_hook (bfd * abfd ATTRIBUTE_UNUSED, void * filehdr)
1617 struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1619 if (BADMAG (*internal_f))
1620 return FALSE;
1622 /* If the optional header is NULL or not the correct size then
1623 quit; the only difference I can see between m88k dgux headers (MC88DMAGIC)
1624 and Intel 960 readwrite headers (I960WRMAGIC) is that the
1625 optional header is of a different size.
1627 But the mips keeps extra stuff in it's opthdr, so dont check
1628 when doing that. */
1630 #if defined(M88) || defined(I960)
1631 if (internal_f->f_opthdr != 0 && bfd_coff_aoutsz (abfd) != internal_f->f_opthdr)
1632 return FALSE;
1633 #endif
1635 return TRUE;
1638 #ifdef TICOFF
1639 static bfd_boolean
1640 ticoff0_bad_format_hook (bfd *abfd ATTRIBUTE_UNUSED, void * filehdr)
1642 struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1644 if (COFF0_BADMAG (*internal_f))
1645 return FALSE;
1647 return TRUE;
1649 #endif
1651 #ifdef TICOFF
1652 static bfd_boolean
1653 ticoff1_bad_format_hook (bfd *abfd ATTRIBUTE_UNUSED, void * filehdr)
1655 struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1657 if (COFF1_BADMAG (*internal_f))
1658 return FALSE;
1660 return TRUE;
1662 #endif
1664 /* Check whether this section uses an alignment other than the
1665 default. */
1667 static void
1668 coff_set_custom_section_alignment (bfd *abfd ATTRIBUTE_UNUSED,
1669 asection *section,
1670 const struct coff_section_alignment_entry *alignment_table,
1671 const unsigned int table_size)
1673 const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1674 unsigned int i;
1676 for (i = 0; i < table_size; ++i)
1678 const char *secname = bfd_get_section_name (abfd, section);
1680 if (alignment_table[i].comparison_length == (unsigned int) -1
1681 ? strcmp (alignment_table[i].name, secname) == 0
1682 : strncmp (alignment_table[i].name, secname,
1683 alignment_table[i].comparison_length) == 0)
1684 break;
1686 if (i >= table_size)
1687 return;
1689 if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1690 && default_alignment < alignment_table[i].default_alignment_min)
1691 return;
1693 if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1694 #if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1695 && default_alignment > alignment_table[i].default_alignment_max
1696 #endif
1698 return;
1700 section->alignment_power = alignment_table[i].alignment_power;
1703 /* Custom section alignment records. */
1705 static const struct coff_section_alignment_entry
1706 coff_section_alignment_table[] =
1708 #ifdef COFF_SECTION_ALIGNMENT_ENTRIES
1709 COFF_SECTION_ALIGNMENT_ENTRIES,
1710 #endif
1711 /* There must not be any gaps between .stabstr sections. */
1712 { COFF_SECTION_NAME_PARTIAL_MATCH (".stabstr"),
1713 1, COFF_ALIGNMENT_FIELD_EMPTY, 0 },
1714 /* The .stab section must be aligned to 2**2 at most, to avoid gaps. */
1715 { COFF_SECTION_NAME_PARTIAL_MATCH (".stab"),
1716 3, COFF_ALIGNMENT_FIELD_EMPTY, 2 },
1717 /* Similarly for the .ctors and .dtors sections. */
1718 { COFF_SECTION_NAME_EXACT_MATCH (".ctors"),
1719 3, COFF_ALIGNMENT_FIELD_EMPTY, 2 },
1720 { COFF_SECTION_NAME_EXACT_MATCH (".dtors"),
1721 3, COFF_ALIGNMENT_FIELD_EMPTY, 2 }
1724 static const unsigned int coff_section_alignment_table_size =
1725 sizeof coff_section_alignment_table / sizeof coff_section_alignment_table[0];
1727 /* Initialize a section structure with information peculiar to this
1728 particular implementation of COFF. */
1730 static bfd_boolean
1731 coff_new_section_hook (bfd * abfd, asection * section)
1733 combined_entry_type *native;
1734 bfd_size_type amt;
1735 unsigned char sclass = C_STAT;
1737 section->alignment_power = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1739 #ifdef RS6000COFF_C
1740 if (bfd_xcoff_text_align_power (abfd) != 0
1741 && strcmp (bfd_get_section_name (abfd, section), ".text") == 0)
1742 section->alignment_power = bfd_xcoff_text_align_power (abfd);
1743 else if (bfd_xcoff_data_align_power (abfd) != 0
1744 && strcmp (bfd_get_section_name (abfd, section), ".data") == 0)
1745 section->alignment_power = bfd_xcoff_data_align_power (abfd);
1746 else
1748 int i;
1750 for (i = 0; i < XCOFF_DWSECT_NBR_NAMES; i++)
1751 if (strcmp (bfd_get_section_name (abfd, section),
1752 xcoff_dwsect_names[i].name) == 0)
1754 section->alignment_power = 0;
1755 sclass = C_DWARF;
1756 break;
1759 #endif
1761 /* Set up the section symbol. */
1762 if (!_bfd_generic_new_section_hook (abfd, section))
1763 return FALSE;
1765 /* Allocate aux records for section symbols, to store size and
1766 related info.
1768 @@ The 10 is a guess at a plausible maximum number of aux entries
1769 (but shouldn't be a constant). */
1770 amt = sizeof (combined_entry_type) * 10;
1771 native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1772 if (native == NULL)
1773 return FALSE;
1775 /* We don't need to set up n_name, n_value, or n_scnum in the native
1776 symbol information, since they'll be overridden by the BFD symbol
1777 anyhow. However, we do need to set the type and storage class,
1778 in case this symbol winds up getting written out. The value 0
1779 for n_numaux is already correct. */
1781 native->u.syment.n_type = T_NULL;
1782 native->u.syment.n_sclass = sclass;
1784 coffsymbol (section->symbol)->native = native;
1786 coff_set_custom_section_alignment (abfd, section,
1787 coff_section_alignment_table,
1788 coff_section_alignment_table_size);
1790 return TRUE;
1793 #ifdef COFF_ALIGN_IN_SECTION_HEADER
1795 /* Set the alignment of a BFD section. */
1797 static void
1798 coff_set_alignment_hook (bfd * abfd ATTRIBUTE_UNUSED,
1799 asection * section,
1800 void * scnhdr)
1802 struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1803 unsigned int i;
1805 #ifdef I960
1806 /* Extract ALIGN from 2**ALIGN stored in section header. */
1807 for (i = 0; i < 32; i++)
1808 if ((1 << i) >= hdr->s_align)
1809 break;
1810 #endif
1811 #ifdef TIC80COFF
1812 /* TI tools puts the alignment power in bits 8-11. */
1813 i = (hdr->s_flags >> 8) & 0xF ;
1814 #endif
1815 #ifdef COFF_DECODE_ALIGNMENT
1816 i = COFF_DECODE_ALIGNMENT(hdr->s_flags);
1817 #endif
1818 section->alignment_power = i;
1820 #ifdef coff_set_section_load_page
1821 coff_set_section_load_page (section, hdr->s_page);
1822 #endif
1825 #else /* ! COFF_ALIGN_IN_SECTION_HEADER */
1826 #ifdef COFF_WITH_PE
1828 static void
1829 coff_set_alignment_hook (bfd * abfd ATTRIBUTE_UNUSED,
1830 asection * section,
1831 void * scnhdr)
1833 struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1834 bfd_size_type amt;
1835 unsigned int alignment_power_const
1836 = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1838 switch (alignment_power_const)
1840 case IMAGE_SCN_ALIGN_8192BYTES:
1841 case IMAGE_SCN_ALIGN_4096BYTES:
1842 case IMAGE_SCN_ALIGN_2048BYTES:
1843 case IMAGE_SCN_ALIGN_1024BYTES:
1844 case IMAGE_SCN_ALIGN_512BYTES:
1845 case IMAGE_SCN_ALIGN_256BYTES:
1846 case IMAGE_SCN_ALIGN_128BYTES:
1847 case IMAGE_SCN_ALIGN_64BYTES:
1848 case IMAGE_SCN_ALIGN_32BYTES:
1849 case IMAGE_SCN_ALIGN_16BYTES:
1850 case IMAGE_SCN_ALIGN_8BYTES:
1851 case IMAGE_SCN_ALIGN_4BYTES:
1852 case IMAGE_SCN_ALIGN_2BYTES:
1853 case IMAGE_SCN_ALIGN_1BYTES:
1854 section->alignment_power
1855 = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1856 break;
1857 default:
1858 break;
1861 /* In a PE image file, the s_paddr field holds the virtual size of a
1862 section, while the s_size field holds the raw size. We also keep
1863 the original section flag value, since not every bit can be
1864 mapped onto a generic BFD section bit. */
1865 if (coff_section_data (abfd, section) == NULL)
1867 amt = sizeof (struct coff_section_tdata);
1868 section->used_by_bfd = bfd_zalloc (abfd, amt);
1869 if (section->used_by_bfd == NULL)
1870 /* FIXME: Return error. */
1871 abort ();
1874 if (pei_section_data (abfd, section) == NULL)
1876 amt = sizeof (struct pei_section_tdata);
1877 coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1878 if (coff_section_data (abfd, section)->tdata == NULL)
1879 /* FIXME: Return error. */
1880 abort ();
1882 pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1883 pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1885 section->lma = hdr->s_vaddr;
1887 /* Check for extended relocs. */
1888 if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1890 struct external_reloc dst;
1891 struct internal_reloc n;
1892 file_ptr oldpos = bfd_tell (abfd);
1893 bfd_size_type relsz = bfd_coff_relsz (abfd);
1895 if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1896 return;
1897 if (bfd_bread (& dst, relsz, abfd) != relsz)
1898 return;
1900 coff_swap_reloc_in (abfd, &dst, &n);
1901 if (bfd_seek (abfd, oldpos, 0) != 0)
1902 return;
1903 section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1904 section->rel_filepos += relsz;
1906 else if (hdr->s_nreloc == 0xffff)
1907 (*_bfd_error_handler)
1908 ("%s: warning: claims to have 0xffff relocs, without overflow",
1909 bfd_get_filename (abfd));
1911 #undef ALIGN_SET
1912 #undef ELIFALIGN_SET
1914 #else /* ! COFF_WITH_PE */
1915 #ifdef RS6000COFF_C
1917 /* We grossly abuse this function to handle XCOFF overflow headers.
1918 When we see one, we correct the reloc and line number counts in the
1919 real header, and remove the section we just created. */
1921 static void
1922 coff_set_alignment_hook (bfd *abfd, asection *section, void * scnhdr)
1924 struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1925 asection *real_sec;
1927 if ((hdr->s_flags & STYP_OVRFLO) == 0)
1928 return;
1930 real_sec = coff_section_from_bfd_index (abfd, (int) hdr->s_nreloc);
1931 if (real_sec == NULL)
1932 return;
1934 real_sec->reloc_count = hdr->s_paddr;
1935 real_sec->lineno_count = hdr->s_vaddr;
1937 if (!bfd_section_removed_from_list (abfd, section))
1939 bfd_section_list_remove (abfd, section);
1940 --abfd->section_count;
1944 #else /* ! RS6000COFF_C */
1946 #define coff_set_alignment_hook \
1947 ((void (*) (bfd *, asection *, void *)) bfd_void)
1949 #endif /* ! RS6000COFF_C */
1950 #endif /* ! COFF_WITH_PE */
1951 #endif /* ! COFF_ALIGN_IN_SECTION_HEADER */
1953 #ifndef coff_mkobject
1955 static bfd_boolean
1956 coff_mkobject (bfd * abfd)
1958 coff_data_type *coff;
1959 bfd_size_type amt = sizeof (coff_data_type);
1961 abfd->tdata.coff_obj_data = bfd_zalloc (abfd, amt);
1962 if (abfd->tdata.coff_obj_data == NULL)
1963 return FALSE;
1964 coff = coff_data (abfd);
1965 coff->symbols = NULL;
1966 coff->conversion_table = NULL;
1967 coff->raw_syments = NULL;
1968 coff->relocbase = 0;
1969 coff->local_toc_sym_map = 0;
1971 /* make_abs_section(abfd);*/
1973 return TRUE;
1975 #endif
1977 /* Create the COFF backend specific information. */
1979 #ifndef coff_mkobject_hook
1980 static void *
1981 coff_mkobject_hook (bfd * abfd,
1982 void * filehdr,
1983 void * aouthdr ATTRIBUTE_UNUSED)
1985 struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1986 coff_data_type *coff;
1988 if (! coff_mkobject (abfd))
1989 return NULL;
1991 coff = coff_data (abfd);
1993 coff->sym_filepos = internal_f->f_symptr;
1995 /* These members communicate important constants about the symbol
1996 table to GDB's symbol-reading code. These `constants'
1997 unfortunately vary among coff implementations... */
1998 coff->local_n_btmask = N_BTMASK;
1999 coff->local_n_btshft = N_BTSHFT;
2000 coff->local_n_tmask = N_TMASK;
2001 coff->local_n_tshift = N_TSHIFT;
2002 coff->local_symesz = bfd_coff_symesz (abfd);
2003 coff->local_auxesz = bfd_coff_auxesz (abfd);
2004 coff->local_linesz = bfd_coff_linesz (abfd);
2006 coff->timestamp = internal_f->f_timdat;
2008 obj_raw_syment_count (abfd) =
2009 obj_conv_table_size (abfd) =
2010 internal_f->f_nsyms;
2012 #ifdef RS6000COFF_C
2013 if ((internal_f->f_flags & F_SHROBJ) != 0)
2014 abfd->flags |= DYNAMIC;
2015 if (aouthdr != NULL && internal_f->f_opthdr >= bfd_coff_aoutsz (abfd))
2017 struct internal_aouthdr *internal_a =
2018 (struct internal_aouthdr *) aouthdr;
2019 struct xcoff_tdata *xcoff;
2021 xcoff = xcoff_data (abfd);
2022 # ifdef U803XTOCMAGIC
2023 xcoff->xcoff64 = internal_f->f_magic == U803XTOCMAGIC;
2024 # else
2025 xcoff->xcoff64 = 0;
2026 # endif
2027 xcoff->full_aouthdr = TRUE;
2028 xcoff->toc = internal_a->o_toc;
2029 xcoff->sntoc = internal_a->o_sntoc;
2030 xcoff->snentry = internal_a->o_snentry;
2031 bfd_xcoff_text_align_power (abfd) = internal_a->o_algntext;
2032 bfd_xcoff_data_align_power (abfd) = internal_a->o_algndata;
2033 xcoff->modtype = internal_a->o_modtype;
2034 xcoff->cputype = internal_a->o_cputype;
2035 xcoff->maxdata = internal_a->o_maxdata;
2036 xcoff->maxstack = internal_a->o_maxstack;
2038 #endif
2040 #ifdef ARM
2041 /* Set the flags field from the COFF header read in. */
2042 if (! _bfd_coff_arm_set_private_flags (abfd, internal_f->f_flags))
2043 coff->flags = 0;
2044 #endif
2046 #ifdef COFF_WITH_PE
2047 /* FIXME: I'm not sure this is ever executed, since peicode.h
2048 defines coff_mkobject_hook. */
2049 if ((internal_f->f_flags & IMAGE_FILE_DEBUG_STRIPPED) == 0)
2050 abfd->flags |= HAS_DEBUG;
2051 #endif
2053 if ((internal_f->f_flags & F_GO32STUB) != 0)
2054 coff->go32stub = (char *) bfd_alloc (abfd, (bfd_size_type) GO32_STUBSIZE);
2055 if (coff->go32stub != NULL)
2056 memcpy (coff->go32stub, internal_f->go32stub, GO32_STUBSIZE);
2058 return coff;
2060 #endif
2062 /* Determine the machine architecture and type. FIXME: This is target
2063 dependent because the magic numbers are defined in the target
2064 dependent header files. But there is no particular need for this.
2065 If the magic numbers were moved to a separate file, this function
2066 would be target independent and would also be much more successful
2067 at linking together COFF files for different architectures. */
2069 static bfd_boolean
2070 coff_set_arch_mach_hook (bfd *abfd, void * filehdr)
2072 unsigned long machine;
2073 enum bfd_architecture arch;
2074 struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2076 /* Zero selects the default machine for an arch. */
2077 machine = 0;
2078 switch (internal_f->f_magic)
2080 #ifdef OR32_MAGIC_BIG
2081 case OR32_MAGIC_BIG:
2082 case OR32_MAGIC_LITTLE:
2083 arch = bfd_arch_or32;
2084 break;
2085 #endif
2086 #ifdef PPCMAGIC
2087 case PPCMAGIC:
2088 arch = bfd_arch_powerpc;
2089 break;
2090 #endif
2091 #ifdef I386MAGIC
2092 case I386MAGIC:
2093 case I386PTXMAGIC:
2094 case I386AIXMAGIC: /* Danbury PS/2 AIX C Compiler. */
2095 case LYNXCOFFMAGIC: /* Shadows the m68k Lynx number below, sigh. */
2096 arch = bfd_arch_i386;
2097 break;
2098 #endif
2099 #ifdef AMD64MAGIC
2100 case AMD64MAGIC:
2101 arch = bfd_arch_i386;
2102 machine = bfd_mach_x86_64;
2103 break;
2104 #endif
2105 #ifdef IA64MAGIC
2106 case IA64MAGIC:
2107 arch = bfd_arch_ia64;
2108 break;
2109 #endif
2110 #ifdef ARMMAGIC
2111 case ARMMAGIC:
2112 case ARMPEMAGIC:
2113 case THUMBPEMAGIC:
2114 arch = bfd_arch_arm;
2115 machine = bfd_arm_get_mach_from_notes (abfd, ARM_NOTE_SECTION);
2116 if (machine == bfd_mach_arm_unknown)
2118 switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
2120 case F_ARM_2: machine = bfd_mach_arm_2; break;
2121 case F_ARM_2a: machine = bfd_mach_arm_2a; break;
2122 case F_ARM_3: machine = bfd_mach_arm_3; break;
2123 default:
2124 case F_ARM_3M: machine = bfd_mach_arm_3M; break;
2125 case F_ARM_4: machine = bfd_mach_arm_4; break;
2126 case F_ARM_4T: machine = bfd_mach_arm_4T; break;
2127 /* The COFF header does not have enough bits available
2128 to cover all the different ARM architectures. So
2129 we interpret F_ARM_5, the highest flag value to mean
2130 "the highest ARM architecture known to BFD" which is
2131 currently the XScale. */
2132 case F_ARM_5: machine = bfd_mach_arm_XScale; break;
2135 break;
2136 #endif
2137 #ifdef MC68MAGIC
2138 case MC68MAGIC:
2139 case M68MAGIC:
2140 #ifdef MC68KBCSMAGIC
2141 case MC68KBCSMAGIC:
2142 #endif
2143 #ifdef APOLLOM68KMAGIC
2144 case APOLLOM68KMAGIC:
2145 #endif
2146 #ifdef LYNXCOFFMAGIC
2147 case LYNXCOFFMAGIC:
2148 #endif
2149 arch = bfd_arch_m68k;
2150 machine = bfd_mach_m68020;
2151 break;
2152 #endif
2153 #ifdef MC88MAGIC
2154 case MC88MAGIC:
2155 case MC88DMAGIC:
2156 case MC88OMAGIC:
2157 arch = bfd_arch_m88k;
2158 machine = 88100;
2159 break;
2160 #endif
2161 #ifdef Z80MAGIC
2162 case Z80MAGIC:
2163 arch = bfd_arch_z80;
2164 switch (internal_f->f_flags & F_MACHMASK)
2166 case 0:
2167 case bfd_mach_z80strict << 12:
2168 case bfd_mach_z80 << 12:
2169 case bfd_mach_z80full << 12:
2170 case bfd_mach_r800 << 12:
2171 machine = ((unsigned)internal_f->f_flags & F_MACHMASK) >> 12;
2172 break;
2173 default:
2174 return FALSE;
2176 break;
2177 #endif
2178 #ifdef Z8KMAGIC
2179 case Z8KMAGIC:
2180 arch = bfd_arch_z8k;
2181 switch (internal_f->f_flags & F_MACHMASK)
2183 case F_Z8001:
2184 machine = bfd_mach_z8001;
2185 break;
2186 case F_Z8002:
2187 machine = bfd_mach_z8002;
2188 break;
2189 default:
2190 return FALSE;
2192 break;
2193 #endif
2194 #ifdef I860
2195 case I860MAGIC:
2196 arch = bfd_arch_i860;
2197 break;
2198 #endif
2199 #ifdef I960
2200 #ifdef I960ROMAGIC
2201 case I960ROMAGIC:
2202 case I960RWMAGIC:
2203 arch = bfd_arch_i960;
2204 switch (F_I960TYPE & internal_f->f_flags)
2206 default:
2207 case F_I960CORE:
2208 machine = bfd_mach_i960_core;
2209 break;
2210 case F_I960KB:
2211 machine = bfd_mach_i960_kb_sb;
2212 break;
2213 case F_I960MC:
2214 machine = bfd_mach_i960_mc;
2215 break;
2216 case F_I960XA:
2217 machine = bfd_mach_i960_xa;
2218 break;
2219 case F_I960CA:
2220 machine = bfd_mach_i960_ca;
2221 break;
2222 case F_I960KA:
2223 machine = bfd_mach_i960_ka_sa;
2224 break;
2225 case F_I960JX:
2226 machine = bfd_mach_i960_jx;
2227 break;
2228 case F_I960HX:
2229 machine = bfd_mach_i960_hx;
2230 break;
2232 break;
2233 #endif
2234 #endif
2236 #ifdef RS6000COFF_C
2237 #ifdef XCOFF64
2238 case U64_TOCMAGIC:
2239 case U803XTOCMAGIC:
2240 #else
2241 case U802ROMAGIC:
2242 case U802WRMAGIC:
2243 case U802TOCMAGIC:
2244 #endif
2246 int cputype;
2248 if (xcoff_data (abfd)->cputype != -1)
2249 cputype = xcoff_data (abfd)->cputype & 0xff;
2250 else
2252 /* We did not get a value from the a.out header. If the
2253 file has not been stripped, we may be able to get the
2254 architecture information from the first symbol, if it
2255 is a .file symbol. */
2256 if (obj_raw_syment_count (abfd) == 0)
2257 cputype = 0;
2258 else
2260 bfd_byte *buf;
2261 struct internal_syment sym;
2262 bfd_size_type amt = bfd_coff_symesz (abfd);
2264 buf = bfd_malloc (amt);
2265 if (bfd_seek (abfd, obj_sym_filepos (abfd), SEEK_SET) != 0
2266 || bfd_bread (buf, amt, abfd) != amt)
2268 free (buf);
2269 return FALSE;
2271 bfd_coff_swap_sym_in (abfd, buf, & sym);
2272 if (sym.n_sclass == C_FILE)
2273 cputype = sym.n_type & 0xff;
2274 else
2275 cputype = 0;
2276 free (buf);
2280 /* FIXME: We don't handle all cases here. */
2281 switch (cputype)
2283 default:
2284 case 0:
2285 arch = bfd_xcoff_architecture (abfd);
2286 machine = bfd_xcoff_machine (abfd);
2287 break;
2289 case 1:
2290 arch = bfd_arch_powerpc;
2291 machine = bfd_mach_ppc_601;
2292 break;
2293 case 2: /* 64 bit PowerPC */
2294 arch = bfd_arch_powerpc;
2295 machine = bfd_mach_ppc_620;
2296 break;
2297 case 3:
2298 arch = bfd_arch_powerpc;
2299 machine = bfd_mach_ppc;
2300 break;
2301 case 4:
2302 arch = bfd_arch_rs6000;
2303 machine = bfd_mach_rs6k;
2304 break;
2307 break;
2308 #endif
2310 #ifdef WE32KMAGIC
2311 case WE32KMAGIC:
2312 arch = bfd_arch_we32k;
2313 break;
2314 #endif
2316 #ifdef H8300MAGIC
2317 case H8300MAGIC:
2318 arch = bfd_arch_h8300;
2319 machine = bfd_mach_h8300;
2320 /* !! FIXME this probably isn't the right place for this. */
2321 abfd->flags |= BFD_IS_RELAXABLE;
2322 break;
2323 #endif
2325 #ifdef H8300HMAGIC
2326 case H8300HMAGIC:
2327 arch = bfd_arch_h8300;
2328 machine = bfd_mach_h8300h;
2329 /* !! FIXME this probably isn't the right place for this. */
2330 abfd->flags |= BFD_IS_RELAXABLE;
2331 break;
2332 #endif
2334 #ifdef H8300SMAGIC
2335 case H8300SMAGIC:
2336 arch = bfd_arch_h8300;
2337 machine = bfd_mach_h8300s;
2338 /* !! FIXME this probably isn't the right place for this. */
2339 abfd->flags |= BFD_IS_RELAXABLE;
2340 break;
2341 #endif
2343 #ifdef H8300HNMAGIC
2344 case H8300HNMAGIC:
2345 arch = bfd_arch_h8300;
2346 machine = bfd_mach_h8300hn;
2347 /* !! FIXME this probably isn't the right place for this. */
2348 abfd->flags |= BFD_IS_RELAXABLE;
2349 break;
2350 #endif
2352 #ifdef H8300SNMAGIC
2353 case H8300SNMAGIC:
2354 arch = bfd_arch_h8300;
2355 machine = bfd_mach_h8300sn;
2356 /* !! FIXME this probably isn't the right place for this. */
2357 abfd->flags |= BFD_IS_RELAXABLE;
2358 break;
2359 #endif
2361 #ifdef SH_ARCH_MAGIC_BIG
2362 case SH_ARCH_MAGIC_BIG:
2363 case SH_ARCH_MAGIC_LITTLE:
2364 #ifdef COFF_WITH_PE
2365 case SH_ARCH_MAGIC_WINCE:
2366 #endif
2367 arch = bfd_arch_sh;
2368 break;
2369 #endif
2371 #ifdef MIPS_ARCH_MAGIC_WINCE
2372 case MIPS_ARCH_MAGIC_WINCE:
2373 arch = bfd_arch_mips;
2374 break;
2375 #endif
2377 #ifdef H8500MAGIC
2378 case H8500MAGIC:
2379 arch = bfd_arch_h8500;
2380 break;
2381 #endif
2383 #ifdef SPARCMAGIC
2384 case SPARCMAGIC:
2385 #ifdef LYNXCOFFMAGIC
2386 case LYNXCOFFMAGIC:
2387 #endif
2388 arch = bfd_arch_sparc;
2389 break;
2390 #endif
2392 #ifdef TIC30MAGIC
2393 case TIC30MAGIC:
2394 arch = bfd_arch_tic30;
2395 break;
2396 #endif
2398 #ifdef TICOFF0MAGIC
2399 #ifdef TICOFF_TARGET_ARCH
2400 /* This TI COFF section should be used by all new TI COFF v0 targets. */
2401 case TICOFF0MAGIC:
2402 arch = TICOFF_TARGET_ARCH;
2403 machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2404 break;
2405 #endif
2406 #endif
2408 #ifdef TICOFF1MAGIC
2409 /* This TI COFF section should be used by all new TI COFF v1/2 targets. */
2410 /* TI COFF1 and COFF2 use the target_id field to specify which arch. */
2411 case TICOFF1MAGIC:
2412 case TICOFF2MAGIC:
2413 switch (internal_f->f_target_id)
2415 #ifdef TI_TARGET_ID
2416 case TI_TARGET_ID:
2417 arch = TICOFF_TARGET_ARCH;
2418 machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2419 break;
2420 #endif
2421 default:
2422 arch = bfd_arch_obscure;
2423 (*_bfd_error_handler)
2424 (_("Unrecognized TI COFF target id '0x%x'"),
2425 internal_f->f_target_id);
2426 break;
2428 break;
2429 #endif
2431 #ifdef TIC80_ARCH_MAGIC
2432 case TIC80_ARCH_MAGIC:
2433 arch = bfd_arch_tic80;
2434 break;
2435 #endif
2437 #ifdef MCOREMAGIC
2438 case MCOREMAGIC:
2439 arch = bfd_arch_mcore;
2440 break;
2441 #endif
2443 #ifdef W65MAGIC
2444 case W65MAGIC:
2445 arch = bfd_arch_w65;
2446 break;
2447 #endif
2449 default: /* Unreadable input file type. */
2450 arch = bfd_arch_obscure;
2451 break;
2454 bfd_default_set_arch_mach (abfd, arch, machine);
2455 return TRUE;
2458 #ifdef SYMNAME_IN_DEBUG
2460 static bfd_boolean
2461 symname_in_debug_hook (bfd * abfd ATTRIBUTE_UNUSED, struct internal_syment *sym)
2463 return SYMNAME_IN_DEBUG (sym) != 0;
2466 #else
2468 #define symname_in_debug_hook \
2469 (bfd_boolean (*) (bfd *, struct internal_syment *)) bfd_false
2471 #endif
2473 #ifdef RS6000COFF_C
2475 #ifdef XCOFF64
2476 #define FORCE_SYMNAMES_IN_STRINGS
2477 #endif
2479 /* Handle the csect auxent of a C_EXT, C_AIX_WEAKEXT or C_HIDEXT symbol. */
2481 static bfd_boolean
2482 coff_pointerize_aux_hook (bfd *abfd ATTRIBUTE_UNUSED,
2483 combined_entry_type *table_base,
2484 combined_entry_type *symbol,
2485 unsigned int indaux,
2486 combined_entry_type *aux)
2488 int n_sclass = symbol->u.syment.n_sclass;
2490 if (CSECT_SYM_P (n_sclass)
2491 && indaux + 1 == symbol->u.syment.n_numaux)
2493 if (SMTYP_SMTYP (aux->u.auxent.x_csect.x_smtyp) == XTY_LD)
2495 aux->u.auxent.x_csect.x_scnlen.p =
2496 table_base + aux->u.auxent.x_csect.x_scnlen.l;
2497 aux->fix_scnlen = 1;
2500 /* Return TRUE to indicate that the caller should not do any
2501 further work on this auxent. */
2502 return TRUE;
2505 /* Return FALSE to indicate that this auxent should be handled by
2506 the caller. */
2507 return FALSE;
2510 #else
2511 #ifdef I960
2513 /* We don't want to pointerize bal entries. */
2515 static bfd_boolean
2516 coff_pointerize_aux_hook (bfd *abfd ATTRIBUTE_UNUSED,
2517 combined_entry_type *table_base ATTRIBUTE_UNUSED,
2518 combined_entry_type *symbol,
2519 unsigned int indaux,
2520 combined_entry_type *aux ATTRIBUTE_UNUSED)
2522 /* Return TRUE if we don't want to pointerize this aux entry, which
2523 is the case for the lastfirst aux entry for a C_LEAFPROC symbol. */
2524 return (indaux == 1
2525 && (symbol->u.syment.n_sclass == C_LEAFPROC
2526 || symbol->u.syment.n_sclass == C_LEAFSTAT
2527 || symbol->u.syment.n_sclass == C_LEAFEXT));
2530 #else /* ! I960 */
2532 #define coff_pointerize_aux_hook 0
2534 #endif /* ! I960 */
2535 #endif /* ! RS6000COFF_C */
2537 /* Print an aux entry. This returns TRUE if it has printed it. */
2539 static bfd_boolean
2540 coff_print_aux (bfd *abfd ATTRIBUTE_UNUSED,
2541 FILE *file ATTRIBUTE_UNUSED,
2542 combined_entry_type *table_base ATTRIBUTE_UNUSED,
2543 combined_entry_type *symbol ATTRIBUTE_UNUSED,
2544 combined_entry_type *aux ATTRIBUTE_UNUSED,
2545 unsigned int indaux ATTRIBUTE_UNUSED)
2547 #ifdef RS6000COFF_C
2548 if (CSECT_SYM_P (symbol->u.syment.n_sclass)
2549 && indaux + 1 == symbol->u.syment.n_numaux)
2551 /* This is a csect entry. */
2552 fprintf (file, "AUX ");
2553 if (SMTYP_SMTYP (aux->u.auxent.x_csect.x_smtyp) != XTY_LD)
2555 BFD_ASSERT (! aux->fix_scnlen);
2556 #ifdef XCOFF64
2557 fprintf (file, "val %5lld",
2558 (long long) aux->u.auxent.x_csect.x_scnlen.l);
2559 #else
2560 fprintf (file, "val %5ld", (long) aux->u.auxent.x_csect.x_scnlen.l);
2561 #endif
2563 else
2565 fprintf (file, "indx ");
2566 if (! aux->fix_scnlen)
2567 #ifdef XCOFF64
2568 fprintf (file, "%4lld",
2569 (long long) aux->u.auxent.x_csect.x_scnlen.l);
2570 #else
2571 fprintf (file, "%4ld", (long) aux->u.auxent.x_csect.x_scnlen.l);
2572 #endif
2573 else
2574 fprintf (file, "%4ld",
2575 (long) (aux->u.auxent.x_csect.x_scnlen.p - table_base));
2577 fprintf (file,
2578 " prmhsh %ld snhsh %u typ %d algn %d clss %u stb %ld snstb %u",
2579 aux->u.auxent.x_csect.x_parmhash,
2580 (unsigned int) aux->u.auxent.x_csect.x_snhash,
2581 SMTYP_SMTYP (aux->u.auxent.x_csect.x_smtyp),
2582 SMTYP_ALIGN (aux->u.auxent.x_csect.x_smtyp),
2583 (unsigned int) aux->u.auxent.x_csect.x_smclas,
2584 aux->u.auxent.x_csect.x_stab,
2585 (unsigned int) aux->u.auxent.x_csect.x_snstab);
2586 return TRUE;
2588 #endif
2590 /* Return FALSE to indicate that no special action was taken. */
2591 return FALSE;
2595 SUBSUBSECTION
2596 Writing relocations
2598 To write relocations, the back end steps though the
2599 canonical relocation table and create an
2600 @code{internal_reloc}. The symbol index to use is removed from
2601 the @code{offset} field in the symbol table supplied. The
2602 address comes directly from the sum of the section base
2603 address and the relocation offset; the type is dug directly
2604 from the howto field. Then the @code{internal_reloc} is
2605 swapped into the shape of an @code{external_reloc} and written
2606 out to disk.
2610 #ifdef TARG_AUX
2613 /* AUX's ld wants relocations to be sorted. */
2614 static int
2615 compare_arelent_ptr (const void * x, const void * y)
2617 const arelent **a = (const arelent **) x;
2618 const arelent **b = (const arelent **) y;
2619 bfd_size_type aadr = (*a)->address;
2620 bfd_size_type badr = (*b)->address;
2622 return (aadr < badr ? -1 : badr < aadr ? 1 : 0);
2625 #endif /* TARG_AUX */
2627 static bfd_boolean
2628 coff_write_relocs (bfd * abfd, int first_undef)
2630 asection *s;
2632 for (s = abfd->sections; s != NULL; s = s->next)
2634 unsigned int i;
2635 struct external_reloc dst;
2636 arelent **p;
2638 #ifndef TARG_AUX
2639 p = s->orelocation;
2640 #else
2642 /* Sort relocations before we write them out. */
2643 bfd_size_type amt;
2645 amt = s->reloc_count;
2646 amt *= sizeof (arelent *);
2647 p = bfd_malloc (amt);
2648 if (p == NULL && s->reloc_count > 0)
2649 return FALSE;
2650 memcpy (p, s->orelocation, (size_t) amt);
2651 qsort (p, s->reloc_count, sizeof (arelent *), compare_arelent_ptr);
2653 #endif
2655 if (bfd_seek (abfd, s->rel_filepos, SEEK_SET) != 0)
2656 return FALSE;
2658 #ifdef COFF_WITH_PE
2659 if (obj_pe (abfd) && s->reloc_count >= 0xffff)
2661 /* Encode real count here as first reloc. */
2662 struct internal_reloc n;
2664 memset (& n, 0, sizeof (n));
2665 /* Add one to count *this* reloc (grr). */
2666 n.r_vaddr = s->reloc_count + 1;
2667 coff_swap_reloc_out (abfd, &n, &dst);
2668 if (bfd_bwrite (& dst, (bfd_size_type) bfd_coff_relsz (abfd),
2669 abfd) != bfd_coff_relsz (abfd))
2670 return FALSE;
2672 #endif
2674 for (i = 0; i < s->reloc_count; i++)
2676 struct internal_reloc n;
2677 arelent *q = p[i];
2679 memset (& n, 0, sizeof (n));
2681 /* Now we've renumbered the symbols we know where the
2682 undefined symbols live in the table. Check the reloc
2683 entries for symbols who's output bfd isn't the right one.
2684 This is because the symbol was undefined (which means
2685 that all the pointers are never made to point to the same
2686 place). This is a bad thing,'cause the symbols attached
2687 to the output bfd are indexed, so that the relocation
2688 entries know which symbol index they point to. So we
2689 have to look up the output symbol here. */
2691 if (q->sym_ptr_ptr[0] != NULL && q->sym_ptr_ptr[0]->the_bfd != abfd)
2693 int j;
2694 const char *sname = q->sym_ptr_ptr[0]->name;
2695 asymbol **outsyms = abfd->outsymbols;
2697 for (j = first_undef; outsyms[j]; j++)
2699 const char *intable = outsyms[j]->name;
2701 if (strcmp (intable, sname) == 0)
2703 /* Got a hit, so repoint the reloc. */
2704 q->sym_ptr_ptr = outsyms + j;
2705 break;
2710 n.r_vaddr = q->address + s->vma;
2712 #ifdef R_IHCONST
2713 /* The 29k const/consth reloc pair is a real kludge. The consth
2714 part doesn't have a symbol; it has an offset. So rebuilt
2715 that here. */
2716 if (q->howto->type == R_IHCONST)
2717 n.r_symndx = q->addend;
2718 else
2719 #endif
2720 if (q->sym_ptr_ptr && q->sym_ptr_ptr[0] != NULL)
2722 #ifdef SECTION_RELATIVE_ABSOLUTE_SYMBOL_P
2723 if (SECTION_RELATIVE_ABSOLUTE_SYMBOL_P (q, s))
2724 #else
2725 if ((*q->sym_ptr_ptr)->section == bfd_abs_section_ptr
2726 && ((*q->sym_ptr_ptr)->flags & BSF_SECTION_SYM) != 0)
2727 #endif
2728 /* This is a relocation relative to the absolute symbol. */
2729 n.r_symndx = -1;
2730 else
2732 n.r_symndx = get_index ((*(q->sym_ptr_ptr)));
2733 /* Check to see if the symbol reloc points to a symbol
2734 we don't have in our symbol table. */
2735 if (n.r_symndx > obj_conv_table_size (abfd))
2737 bfd_set_error (bfd_error_bad_value);
2738 _bfd_error_handler (_("%B: reloc against a non-existant symbol index: %ld"),
2739 abfd, n.r_symndx);
2740 return FALSE;
2745 #ifdef SWAP_OUT_RELOC_OFFSET
2746 n.r_offset = q->addend;
2747 #endif
2749 #ifdef SELECT_RELOC
2750 /* Work out reloc type from what is required. */
2751 SELECT_RELOC (n, q->howto);
2752 #else
2753 n.r_type = q->howto->type;
2754 #endif
2755 coff_swap_reloc_out (abfd, &n, &dst);
2757 if (bfd_bwrite (& dst, (bfd_size_type) bfd_coff_relsz (abfd),
2758 abfd) != bfd_coff_relsz (abfd))
2759 return FALSE;
2762 #ifdef TARG_AUX
2763 if (p != NULL)
2764 free (p);
2765 #endif
2768 return TRUE;
2771 /* Set flags and magic number of a coff file from architecture and machine
2772 type. Result is TRUE if we can represent the arch&type, FALSE if not. */
2774 static bfd_boolean
2775 coff_set_flags (bfd * abfd,
2776 unsigned int *magicp ATTRIBUTE_UNUSED,
2777 unsigned short *flagsp ATTRIBUTE_UNUSED)
2779 switch (bfd_get_arch (abfd))
2781 #ifdef Z80MAGIC
2782 case bfd_arch_z80:
2783 *magicp = Z80MAGIC;
2784 switch (bfd_get_mach (abfd))
2786 case 0:
2787 case bfd_mach_z80strict:
2788 case bfd_mach_z80:
2789 case bfd_mach_z80full:
2790 case bfd_mach_r800:
2791 *flagsp = bfd_get_mach (abfd) << 12;
2792 break;
2793 default:
2794 return FALSE;
2796 return TRUE;
2797 #endif
2799 #ifdef Z8KMAGIC
2800 case bfd_arch_z8k:
2801 *magicp = Z8KMAGIC;
2803 switch (bfd_get_mach (abfd))
2805 case bfd_mach_z8001: *flagsp = F_Z8001; break;
2806 case bfd_mach_z8002: *flagsp = F_Z8002; break;
2807 default: return FALSE;
2809 return TRUE;
2810 #endif
2812 #ifdef I960ROMAGIC
2813 case bfd_arch_i960:
2816 unsigned flags;
2818 *magicp = I960ROMAGIC;
2820 switch (bfd_get_mach (abfd))
2822 case bfd_mach_i960_core: flags = F_I960CORE; break;
2823 case bfd_mach_i960_kb_sb: flags = F_I960KB; break;
2824 case bfd_mach_i960_mc: flags = F_I960MC; break;
2825 case bfd_mach_i960_xa: flags = F_I960XA; break;
2826 case bfd_mach_i960_ca: flags = F_I960CA; break;
2827 case bfd_mach_i960_ka_sa: flags = F_I960KA; break;
2828 case bfd_mach_i960_jx: flags = F_I960JX; break;
2829 case bfd_mach_i960_hx: flags = F_I960HX; break;
2830 default: return FALSE;
2832 *flagsp = flags;
2833 return TRUE;
2835 break;
2836 #endif
2838 #ifdef TIC30MAGIC
2839 case bfd_arch_tic30:
2840 *magicp = TIC30MAGIC;
2841 return TRUE;
2842 #endif
2844 #ifdef TICOFF_DEFAULT_MAGIC
2845 case TICOFF_TARGET_ARCH:
2846 /* If there's no indication of which version we want, use the default. */
2847 if (!abfd->xvec )
2848 *magicp = TICOFF_DEFAULT_MAGIC;
2849 else
2851 /* We may want to output in a different COFF version. */
2852 switch (abfd->xvec->name[4])
2854 case '0':
2855 *magicp = TICOFF0MAGIC;
2856 break;
2857 case '1':
2858 *magicp = TICOFF1MAGIC;
2859 break;
2860 case '2':
2861 *magicp = TICOFF2MAGIC;
2862 break;
2863 default:
2864 return FALSE;
2867 TICOFF_TARGET_MACHINE_SET (flagsp, bfd_get_mach (abfd));
2868 return TRUE;
2869 #endif
2871 #ifdef TIC80_ARCH_MAGIC
2872 case bfd_arch_tic80:
2873 *magicp = TIC80_ARCH_MAGIC;
2874 return TRUE;
2875 #endif
2877 #ifdef ARMMAGIC
2878 case bfd_arch_arm:
2879 #ifdef ARM_WINCE
2880 * magicp = ARMPEMAGIC;
2881 #else
2882 * magicp = ARMMAGIC;
2883 #endif
2884 * flagsp = 0;
2885 if (APCS_SET (abfd))
2887 if (APCS_26_FLAG (abfd))
2888 * flagsp |= F_APCS26;
2890 if (APCS_FLOAT_FLAG (abfd))
2891 * flagsp |= F_APCS_FLOAT;
2893 if (PIC_FLAG (abfd))
2894 * flagsp |= F_PIC;
2896 if (INTERWORK_SET (abfd) && INTERWORK_FLAG (abfd))
2897 * flagsp |= F_INTERWORK;
2898 switch (bfd_get_mach (abfd))
2900 case bfd_mach_arm_2: * flagsp |= F_ARM_2; break;
2901 case bfd_mach_arm_2a: * flagsp |= F_ARM_2a; break;
2902 case bfd_mach_arm_3: * flagsp |= F_ARM_3; break;
2903 case bfd_mach_arm_3M: * flagsp |= F_ARM_3M; break;
2904 case bfd_mach_arm_4: * flagsp |= F_ARM_4; break;
2905 case bfd_mach_arm_4T: * flagsp |= F_ARM_4T; break;
2906 case bfd_mach_arm_5: * flagsp |= F_ARM_5; break;
2907 /* FIXME: we do not have F_ARM vaues greater than F_ARM_5.
2908 See also the comment in coff_set_arch_mach_hook(). */
2909 case bfd_mach_arm_5T: * flagsp |= F_ARM_5; break;
2910 case bfd_mach_arm_5TE: * flagsp |= F_ARM_5; break;
2911 case bfd_mach_arm_XScale: * flagsp |= F_ARM_5; break;
2913 return TRUE;
2914 #endif
2916 #ifdef PPCMAGIC
2917 case bfd_arch_powerpc:
2918 *magicp = PPCMAGIC;
2919 return TRUE;
2920 #endif
2922 #if defined(I386MAGIC) || defined(AMD64MAGIC)
2923 case bfd_arch_i386:
2924 #if defined(I386MAGIC)
2925 *magicp = I386MAGIC;
2926 #endif
2927 #if defined LYNXOS
2928 /* Just overwrite the usual value if we're doing Lynx. */
2929 *magicp = LYNXCOFFMAGIC;
2930 #endif
2931 #if defined AMD64MAGIC
2932 *magicp = AMD64MAGIC;
2933 #endif
2934 return TRUE;
2935 #endif
2937 #ifdef I860MAGIC
2938 case bfd_arch_i860:
2939 *magicp = I860MAGIC;
2940 return TRUE;
2941 #endif
2943 #ifdef IA64MAGIC
2944 case bfd_arch_ia64:
2945 *magicp = IA64MAGIC;
2946 return TRUE;
2947 #endif
2949 #ifdef MC68MAGIC
2950 case bfd_arch_m68k:
2951 #ifdef APOLLOM68KMAGIC
2952 *magicp = APOLLO_COFF_VERSION_NUMBER;
2953 #else
2954 /* NAMES_HAVE_UNDERSCORE may be defined by coff-u68k.c. */
2955 #ifdef NAMES_HAVE_UNDERSCORE
2956 *magicp = MC68KBCSMAGIC;
2957 #else
2958 *magicp = MC68MAGIC;
2959 #endif
2960 #endif
2961 #ifdef LYNXOS
2962 /* Just overwrite the usual value if we're doing Lynx. */
2963 *magicp = LYNXCOFFMAGIC;
2964 #endif
2965 return TRUE;
2966 #endif
2968 #ifdef MC88MAGIC
2969 case bfd_arch_m88k:
2970 *magicp = MC88OMAGIC;
2971 return TRUE;
2972 #endif
2974 #ifdef H8300MAGIC
2975 case bfd_arch_h8300:
2976 switch (bfd_get_mach (abfd))
2978 case bfd_mach_h8300: *magicp = H8300MAGIC; return TRUE;
2979 case bfd_mach_h8300h: *magicp = H8300HMAGIC; return TRUE;
2980 case bfd_mach_h8300s: *magicp = H8300SMAGIC; return TRUE;
2981 case bfd_mach_h8300hn: *magicp = H8300HNMAGIC; return TRUE;
2982 case bfd_mach_h8300sn: *magicp = H8300SNMAGIC; return TRUE;
2983 default: break;
2985 break;
2986 #endif
2988 #ifdef SH_ARCH_MAGIC_BIG
2989 case bfd_arch_sh:
2990 #ifdef COFF_IMAGE_WITH_PE
2991 *magicp = SH_ARCH_MAGIC_WINCE;
2992 #else
2993 if (bfd_big_endian (abfd))
2994 *magicp = SH_ARCH_MAGIC_BIG;
2995 else
2996 *magicp = SH_ARCH_MAGIC_LITTLE;
2997 #endif
2998 return TRUE;
2999 #endif
3001 #ifdef MIPS_ARCH_MAGIC_WINCE
3002 case bfd_arch_mips:
3003 *magicp = MIPS_ARCH_MAGIC_WINCE;
3004 return TRUE;
3005 #endif
3007 #ifdef SPARCMAGIC
3008 case bfd_arch_sparc:
3009 *magicp = SPARCMAGIC;
3010 #ifdef LYNXOS
3011 /* Just overwrite the usual value if we're doing Lynx. */
3012 *magicp = LYNXCOFFMAGIC;
3013 #endif
3014 return TRUE;
3015 #endif
3017 #ifdef H8500MAGIC
3018 case bfd_arch_h8500:
3019 *magicp = H8500MAGIC;
3020 return TRUE;
3021 break;
3022 #endif
3024 #ifdef WE32KMAGIC
3025 case bfd_arch_we32k:
3026 *magicp = WE32KMAGIC;
3027 return TRUE;
3028 #endif
3030 #ifdef RS6000COFF_C
3031 case bfd_arch_rs6000:
3032 #ifndef PPCMAGIC
3033 case bfd_arch_powerpc:
3034 #endif
3035 BFD_ASSERT (bfd_get_flavour (abfd) == bfd_target_xcoff_flavour);
3036 *magicp = bfd_xcoff_magic_number (abfd);
3037 return TRUE;
3038 #endif
3040 #ifdef MCOREMAGIC
3041 case bfd_arch_mcore:
3042 * magicp = MCOREMAGIC;
3043 return TRUE;
3044 #endif
3046 #ifdef W65MAGIC
3047 case bfd_arch_w65:
3048 *magicp = W65MAGIC;
3049 return TRUE;
3050 #endif
3052 #ifdef OR32_MAGIC_BIG
3053 case bfd_arch_or32:
3054 if (bfd_big_endian (abfd))
3055 * magicp = OR32_MAGIC_BIG;
3056 else
3057 * magicp = OR32_MAGIC_LITTLE;
3058 return TRUE;
3059 #endif
3061 default: /* Unknown architecture. */
3062 /* Fall through to "return FALSE" below, to avoid
3063 "statement never reached" errors on the one below. */
3064 break;
3067 return FALSE;
3070 static bfd_boolean
3071 coff_set_arch_mach (bfd * abfd,
3072 enum bfd_architecture arch,
3073 unsigned long machine)
3075 unsigned dummy1;
3076 unsigned short dummy2;
3078 if (! bfd_default_set_arch_mach (abfd, arch, machine))
3079 return FALSE;
3081 if (arch != bfd_arch_unknown
3082 && ! coff_set_flags (abfd, &dummy1, &dummy2))
3083 return FALSE; /* We can't represent this type. */
3085 return TRUE; /* We're easy... */
3088 #ifdef COFF_IMAGE_WITH_PE
3090 /* This is used to sort sections by VMA, as required by PE image
3091 files. */
3093 static int
3094 sort_by_secaddr (const void * arg1, const void * arg2)
3096 const asection *a = *(const asection **) arg1;
3097 const asection *b = *(const asection **) arg2;
3099 if (a->vma < b->vma)
3100 return -1;
3101 else if (a->vma > b->vma)
3102 return 1;
3104 return 0;
3107 #endif /* COFF_IMAGE_WITH_PE */
3109 /* Calculate the file position for each section. */
3111 #ifndef I960
3112 #define ALIGN_SECTIONS_IN_FILE
3113 #endif
3114 #if defined(TIC80COFF) || defined(TICOFF)
3115 #undef ALIGN_SECTIONS_IN_FILE
3116 #endif
3118 static bfd_boolean
3119 coff_compute_section_file_positions (bfd * abfd)
3121 asection *current;
3122 file_ptr sofar = bfd_coff_filhsz (abfd);
3123 bfd_boolean align_adjust;
3124 int target_index;
3125 #ifdef ALIGN_SECTIONS_IN_FILE
3126 asection *previous = NULL;
3127 file_ptr old_sofar;
3128 #endif
3130 #ifdef COFF_IMAGE_WITH_PE
3131 int page_size;
3133 if (coff_data (abfd)->link_info)
3135 page_size = pe_data (abfd)->pe_opthdr.FileAlignment;
3137 /* If no file alignment has been set, default to one.
3138 This repairs 'ld -r' for arm-wince-pe target. */
3139 if (page_size == 0)
3140 page_size = 1;
3142 else
3143 page_size = PE_DEF_FILE_ALIGNMENT;
3144 #else
3145 #ifdef COFF_PAGE_SIZE
3146 int page_size = COFF_PAGE_SIZE;
3147 #endif
3148 #endif
3150 #ifdef RS6000COFF_C
3151 /* On XCOFF, if we have symbols, set up the .debug section. */
3152 if (bfd_get_symcount (abfd) > 0)
3154 bfd_size_type sz;
3155 bfd_size_type i, symcount;
3156 asymbol **symp;
3158 sz = 0;
3159 symcount = bfd_get_symcount (abfd);
3160 for (symp = abfd->outsymbols, i = 0; i < symcount; symp++, i++)
3162 coff_symbol_type *cf;
3164 cf = coff_symbol_from (abfd, *symp);
3165 if (cf != NULL
3166 && cf->native != NULL
3167 && SYMNAME_IN_DEBUG (&cf->native->u.syment))
3169 size_t len;
3171 len = strlen (bfd_asymbol_name (*symp));
3172 if (len > SYMNMLEN || bfd_coff_force_symnames_in_strings (abfd))
3173 sz += len + 1 + bfd_coff_debug_string_prefix_length (abfd);
3176 if (sz > 0)
3178 asection *dsec;
3180 dsec = bfd_make_section_old_way (abfd, DOT_DEBUG);
3181 if (dsec == NULL)
3182 abort ();
3183 dsec->size = sz;
3184 dsec->flags |= SEC_HAS_CONTENTS;
3187 #endif
3189 if (bfd_get_start_address (abfd))
3190 /* A start address may have been added to the original file. In this
3191 case it will need an optional header to record it. */
3192 abfd->flags |= EXEC_P;
3194 if (abfd->flags & EXEC_P)
3195 sofar += bfd_coff_aoutsz (abfd);
3196 #ifdef RS6000COFF_C
3197 else if (xcoff_data (abfd)->full_aouthdr)
3198 sofar += bfd_coff_aoutsz (abfd);
3199 else
3200 sofar += SMALL_AOUTSZ;
3201 #endif
3203 sofar += abfd->section_count * bfd_coff_scnhsz (abfd);
3205 #ifdef RS6000COFF_C
3206 /* XCOFF handles overflows in the reloc and line number count fields
3207 by allocating a new section header to hold the correct counts. */
3208 for (current = abfd->sections; current != NULL; current = current->next)
3209 if (current->reloc_count >= 0xffff || current->lineno_count >= 0xffff)
3210 sofar += bfd_coff_scnhsz (abfd);
3211 #endif
3213 #ifdef COFF_IMAGE_WITH_PE
3215 /* PE requires the sections to be in memory order when listed in
3216 the section headers. It also does not like empty loadable
3217 sections. The sections apparently do not have to be in the
3218 right order in the image file itself, but we do need to get the
3219 target_index values right. */
3221 unsigned int count;
3222 asection **section_list;
3223 unsigned int i;
3224 bfd_size_type amt;
3226 #ifdef COFF_PAGE_SIZE
3227 /* Clear D_PAGED if section alignment is smaller than
3228 COFF_PAGE_SIZE. */
3229 if (pe_data (abfd)->pe_opthdr.SectionAlignment < COFF_PAGE_SIZE)
3230 abfd->flags &= ~D_PAGED;
3231 #endif
3233 count = 0;
3234 for (current = abfd->sections; current != NULL; current = current->next)
3235 ++count;
3237 /* We allocate an extra cell to simplify the final loop. */
3238 amt = sizeof (struct asection *) * (count + 1);
3239 section_list = (asection **) bfd_malloc (amt);
3240 if (section_list == NULL)
3241 return FALSE;
3243 i = 0;
3244 for (current = abfd->sections; current != NULL; current = current->next)
3246 section_list[i] = current;
3247 ++i;
3249 section_list[i] = NULL;
3251 qsort (section_list, count, sizeof (asection *), sort_by_secaddr);
3253 /* Rethread the linked list into sorted order; at the same time,
3254 assign target_index values. */
3255 target_index = 1;
3256 abfd->sections = NULL;
3257 abfd->section_last = NULL;
3258 for (i = 0; i < count; i++)
3260 current = section_list[i];
3261 bfd_section_list_append (abfd, current);
3263 /* Later, if the section has zero size, we'll be throwing it
3264 away, so we don't want to number it now. Note that having
3265 a zero size and having real contents are different
3266 concepts: .bss has no contents, but (usually) non-zero
3267 size. */
3268 if (current->size == 0)
3270 /* Discard. However, it still might have (valid) symbols
3271 in it, so arbitrarily set it to section 1 (indexing is
3272 1-based here; usually .text). __end__ and other
3273 contents of .endsection really have this happen.
3274 FIXME: This seems somewhat dubious. */
3275 current->target_index = 1;
3277 else
3278 current->target_index = target_index++;
3281 free (section_list);
3283 #else /* ! COFF_IMAGE_WITH_PE */
3285 /* Set the target_index field. */
3286 target_index = 1;
3287 for (current = abfd->sections; current != NULL; current = current->next)
3288 current->target_index = target_index++;
3290 #endif /* ! COFF_IMAGE_WITH_PE */
3292 if (target_index >= 32768)
3294 bfd_set_error (bfd_error_file_too_big);
3295 (*_bfd_error_handler)
3296 (_("%B: too many sections (%d)"), abfd, target_index);
3297 return FALSE;
3300 align_adjust = FALSE;
3301 for (current = abfd->sections;
3302 current != NULL;
3303 current = current->next)
3305 #ifdef COFF_IMAGE_WITH_PE
3306 /* With PE we have to pad each section to be a multiple of its
3307 page size too, and remember both sizes. */
3308 if (coff_section_data (abfd, current) == NULL)
3310 bfd_size_type amt = sizeof (struct coff_section_tdata);
3312 current->used_by_bfd = bfd_zalloc (abfd, amt);
3313 if (current->used_by_bfd == NULL)
3314 return FALSE;
3316 if (pei_section_data (abfd, current) == NULL)
3318 bfd_size_type amt = sizeof (struct pei_section_tdata);
3320 coff_section_data (abfd, current)->tdata = bfd_zalloc (abfd, amt);
3321 if (coff_section_data (abfd, current)->tdata == NULL)
3322 return FALSE;
3324 if (pei_section_data (abfd, current)->virt_size == 0)
3325 pei_section_data (abfd, current)->virt_size = current->size;
3326 #endif
3328 /* Only deal with sections which have contents. */
3329 if (!(current->flags & SEC_HAS_CONTENTS))
3330 continue;
3332 current->rawsize = current->size;
3334 #ifdef COFF_IMAGE_WITH_PE
3335 /* Make sure we skip empty sections in a PE image. */
3336 if (current->size == 0)
3337 continue;
3338 #endif
3340 /* Align the sections in the file to the same boundary on
3341 which they are aligned in virtual memory. I960 doesn't
3342 do this (FIXME) so we can stay in sync with Intel. 960
3343 doesn't yet page from files... */
3344 #ifdef ALIGN_SECTIONS_IN_FILE
3345 if ((abfd->flags & EXEC_P) != 0)
3347 /* Make sure this section is aligned on the right boundary - by
3348 padding the previous section up if necessary. */
3349 old_sofar = sofar;
3351 #ifdef RS6000COFF_C
3352 /* AIX loader checks the text section alignment of (vma - filepos)
3353 So even though the filepos may be aligned wrt the o_algntext, for
3354 AIX executables, this check fails. This shows up when a native
3355 AIX executable is stripped with gnu strip because the default vma
3356 of native is 0x10000150 but default for gnu is 0x10000140. Gnu
3357 stripped gnu excutable passes this check because the filepos is
3358 0x0140. This problem also show up with 64 bit shared objects. The
3359 data section must also be aligned. */
3360 if (!strcmp (current->name, _TEXT)
3361 || !strcmp (current->name, _DATA))
3363 bfd_vma pad;
3364 bfd_vma align;
3366 sofar = BFD_ALIGN (sofar, 1 << current->alignment_power);
3368 align = 1 << current->alignment_power;
3369 pad = abs (current->vma - sofar) % align;
3371 if (pad)
3373 pad = align - pad;
3374 sofar += pad;
3377 else
3378 #else
3380 sofar = BFD_ALIGN (sofar, 1 << current->alignment_power);
3382 #endif
3383 if (previous != NULL)
3384 previous->size += sofar - old_sofar;
3387 #endif
3389 /* In demand paged files the low order bits of the file offset
3390 must match the low order bits of the virtual address. */
3391 #ifdef COFF_PAGE_SIZE
3392 if ((abfd->flags & D_PAGED) != 0
3393 && (current->flags & SEC_ALLOC) != 0)
3394 sofar += (current->vma - (bfd_vma) sofar) % page_size;
3395 #endif
3396 current->filepos = sofar;
3398 #ifdef COFF_IMAGE_WITH_PE
3399 /* Set the padded size. */
3400 current->size = (current->size + page_size - 1) & -page_size;
3401 #endif
3403 sofar += current->size;
3405 #ifdef ALIGN_SECTIONS_IN_FILE
3406 /* Make sure that this section is of the right size too. */
3407 if ((abfd->flags & EXEC_P) == 0)
3409 bfd_size_type old_size;
3411 old_size = current->size;
3412 current->size = BFD_ALIGN (current->size,
3413 1 << current->alignment_power);
3414 align_adjust = current->size != old_size;
3415 sofar += current->size - old_size;
3417 else
3419 old_sofar = sofar;
3420 sofar = BFD_ALIGN (sofar, 1 << current->alignment_power);
3421 align_adjust = sofar != old_sofar;
3422 current->size += sofar - old_sofar;
3424 #endif
3426 #ifdef COFF_IMAGE_WITH_PE
3427 /* For PE we need to make sure we pad out to the aligned
3428 size, in case the caller only writes out data to the
3429 unaligned size. */
3430 if (pei_section_data (abfd, current)->virt_size < current->size)
3431 align_adjust = TRUE;
3432 #endif
3434 #ifdef _LIB
3435 /* Force .lib sections to start at zero. The vma is then
3436 incremented in coff_set_section_contents. This is right for
3437 SVR3.2. */
3438 if (strcmp (current->name, _LIB) == 0)
3439 bfd_set_section_vma (abfd, current, 0);
3440 #endif
3442 #ifdef ALIGN_SECTIONS_IN_FILE
3443 previous = current;
3444 #endif
3447 /* It is now safe to write to the output file. If we needed an
3448 alignment adjustment for the last section, then make sure that
3449 there is a byte at offset sofar. If there are no symbols and no
3450 relocs, then nothing follows the last section. If we don't force
3451 the last byte out, then the file may appear to be truncated. */
3452 if (align_adjust)
3454 bfd_byte b;
3456 b = 0;
3457 if (bfd_seek (abfd, sofar - 1, SEEK_SET) != 0
3458 || bfd_bwrite (&b, (bfd_size_type) 1, abfd) != 1)
3459 return FALSE;
3462 /* Make sure the relocations are aligned. We don't need to make
3463 sure that this byte exists, because it will only matter if there
3464 really are relocs. */
3465 sofar = BFD_ALIGN (sofar, 1 << COFF_DEFAULT_SECTION_ALIGNMENT_POWER);
3467 obj_relocbase (abfd) = sofar;
3468 abfd->output_has_begun = TRUE;
3470 return TRUE;
3473 #ifdef COFF_IMAGE_WITH_PE
3475 static unsigned int pelength;
3476 static unsigned int peheader;
3478 static bfd_boolean
3479 coff_read_word (bfd *abfd, unsigned int *value)
3481 unsigned char b[2];
3482 int status;
3484 status = bfd_bread (b, (bfd_size_type) 2, abfd);
3485 if (status < 1)
3487 *value = 0;
3488 return FALSE;
3491 if (status == 1)
3492 *value = (unsigned int) b[0];
3493 else
3494 *value = (unsigned int) (b[0] + (b[1] << 8));
3496 pelength += (unsigned int) status;
3498 return TRUE;
3501 static unsigned int
3502 coff_compute_checksum (bfd *abfd)
3504 bfd_boolean more_data;
3505 file_ptr filepos;
3506 unsigned int value;
3507 unsigned int total;
3509 total = 0;
3510 pelength = 0;
3511 filepos = (file_ptr) 0;
3515 if (bfd_seek (abfd, filepos, SEEK_SET) != 0)
3516 return 0;
3518 more_data = coff_read_word (abfd, &value);
3519 total += value;
3520 total = 0xffff & (total + (total >> 0x10));
3521 filepos += 2;
3523 while (more_data);
3525 return (0xffff & (total + (total >> 0x10)));
3528 static bfd_boolean
3529 coff_apply_checksum (bfd *abfd)
3531 unsigned int computed;
3532 unsigned int checksum = 0;
3534 if (bfd_seek (abfd, 0x3c, SEEK_SET) != 0)
3535 return FALSE;
3537 if (!coff_read_word (abfd, &peheader))
3538 return FALSE;
3540 if (bfd_seek (abfd, peheader + 0x58, SEEK_SET) != 0)
3541 return FALSE;
3543 checksum = 0;
3544 bfd_bwrite (&checksum, (bfd_size_type) 4, abfd);
3546 if (bfd_seek (abfd, peheader, SEEK_SET) != 0)
3547 return FALSE;
3549 computed = coff_compute_checksum (abfd);
3551 checksum = computed + pelength;
3553 if (bfd_seek (abfd, peheader + 0x58, SEEK_SET) != 0)
3554 return FALSE;
3556 bfd_bwrite (&checksum, (bfd_size_type) 4, abfd);
3558 return TRUE;
3561 #endif /* COFF_IMAGE_WITH_PE */
3563 static bfd_boolean
3564 coff_write_object_contents (bfd * abfd)
3566 asection *current;
3567 bfd_boolean hasrelocs = FALSE;
3568 bfd_boolean haslinno = FALSE;
3569 #ifdef COFF_IMAGE_WITH_PE
3570 bfd_boolean hasdebug = FALSE;
3571 #endif
3572 file_ptr scn_base;
3573 file_ptr reloc_base;
3574 file_ptr lineno_base;
3575 file_ptr sym_base;
3576 unsigned long reloc_size = 0, reloc_count = 0;
3577 unsigned long lnno_size = 0;
3578 bfd_boolean long_section_names;
3579 asection *text_sec = NULL;
3580 asection *data_sec = NULL;
3581 asection *bss_sec = NULL;
3582 struct internal_filehdr internal_f;
3583 struct internal_aouthdr internal_a;
3584 #ifdef COFF_LONG_SECTION_NAMES
3585 size_t string_size = STRING_SIZE_SIZE;
3586 #endif
3588 bfd_set_error (bfd_error_system_call);
3590 /* Make a pass through the symbol table to count line number entries and
3591 put them into the correct asections. */
3592 lnno_size = coff_count_linenumbers (abfd) * bfd_coff_linesz (abfd);
3594 if (! abfd->output_has_begun)
3596 if (! coff_compute_section_file_positions (abfd))
3597 return FALSE;
3600 reloc_base = obj_relocbase (abfd);
3602 /* Work out the size of the reloc and linno areas. */
3604 for (current = abfd->sections; current != NULL; current =
3605 current->next)
3607 #ifdef COFF_WITH_PE
3608 /* We store the actual reloc count in the first reloc's addr. */
3609 if (obj_pe (abfd) && current->reloc_count >= 0xffff)
3610 reloc_count ++;
3611 #endif
3612 reloc_count += current->reloc_count;
3615 reloc_size = reloc_count * bfd_coff_relsz (abfd);
3617 lineno_base = reloc_base + reloc_size;
3618 sym_base = lineno_base + lnno_size;
3620 /* Indicate in each section->line_filepos its actual file address. */
3621 for (current = abfd->sections; current != NULL; current =
3622 current->next)
3624 if (current->lineno_count)
3626 current->line_filepos = lineno_base;
3627 current->moving_line_filepos = lineno_base;
3628 lineno_base += current->lineno_count * bfd_coff_linesz (abfd);
3630 else
3631 current->line_filepos = 0;
3633 if (current->reloc_count)
3635 current->rel_filepos = reloc_base;
3636 reloc_base += current->reloc_count * bfd_coff_relsz (abfd);
3637 #ifdef COFF_WITH_PE
3638 /* Extra reloc to hold real count. */
3639 if (obj_pe (abfd) && current->reloc_count >= 0xffff)
3640 reloc_base += bfd_coff_relsz (abfd);
3641 #endif
3643 else
3644 current->rel_filepos = 0;
3647 /* Write section headers to the file. */
3648 internal_f.f_nscns = 0;
3650 if ((abfd->flags & EXEC_P) != 0)
3651 scn_base = bfd_coff_filhsz (abfd) + bfd_coff_aoutsz (abfd);
3652 else
3654 scn_base = bfd_coff_filhsz (abfd);
3655 #ifdef RS6000COFF_C
3656 #ifndef XCOFF64
3657 if (xcoff_data (abfd)->full_aouthdr)
3658 scn_base += bfd_coff_aoutsz (abfd);
3659 else
3660 scn_base += SMALL_AOUTSZ;
3661 #endif
3662 #endif
3665 if (bfd_seek (abfd, scn_base, SEEK_SET) != 0)
3666 return FALSE;
3668 long_section_names = FALSE;
3669 for (current = abfd->sections;
3670 current != NULL;
3671 current = current->next)
3673 struct internal_scnhdr section;
3674 #ifdef COFF_IMAGE_WITH_PE
3675 bfd_boolean is_reloc_section = FALSE;
3677 if (strcmp (current->name, DOT_RELOC) == 0)
3679 is_reloc_section = TRUE;
3680 hasrelocs = TRUE;
3681 pe_data (abfd)->has_reloc_section = 1;
3683 #endif
3685 internal_f.f_nscns++;
3687 strncpy (section.s_name, current->name, SCNNMLEN);
3689 #ifdef COFF_LONG_SECTION_NAMES
3690 /* Handle long section names as in PE. This must be compatible
3691 with the code in coff_write_symbols and _bfd_coff_final_link. */
3692 if (bfd_coff_long_section_names (abfd))
3694 size_t len;
3696 len = strlen (current->name);
3697 if (len > SCNNMLEN)
3699 /* The s_name field is defined to be NUL-padded but need not be
3700 NUL-terminated. We use a temporary buffer so that we can still
3701 sprintf all eight chars without splatting a terminating NUL
3702 over the first byte of the following member (s_paddr). */
3703 char s_name_buf[SCNNMLEN + 1];
3705 /* An inherent limitation of the /nnnnnnn notation used to indicate
3706 the offset of the long name in the string table is that we
3707 cannot address entries beyone the ten million byte boundary. */
3708 if (string_size >= 10000000)
3710 bfd_set_error (bfd_error_file_too_big);
3711 (*_bfd_error_handler)
3712 (_("%B: section %s: string table overflow at offset %ld"),
3713 abfd, current->name, string_size);
3714 return FALSE;
3717 /* snprintf not strictly necessary now we've verified the value
3718 has less than eight ASCII digits, but never mind. */
3719 snprintf (s_name_buf, SCNNMLEN + 1, "/%lu", (unsigned long) string_size);
3720 /* Then strncpy takes care of any padding for us. */
3721 strncpy (section.s_name, s_name_buf, SCNNMLEN);
3722 string_size += len + 1;
3723 long_section_names = TRUE;
3726 #endif
3728 #ifdef _LIB
3729 /* Always set s_vaddr of .lib to 0. This is right for SVR3.2
3730 Ian Taylor <ian@cygnus.com>. */
3731 if (strcmp (current->name, _LIB) == 0)
3732 section.s_vaddr = 0;
3733 else
3734 #endif
3735 section.s_vaddr = current->vma;
3736 section.s_paddr = current->lma;
3737 section.s_size = current->size;
3738 #ifdef coff_get_section_load_page
3739 section.s_page = coff_get_section_load_page (current);
3740 #else
3741 section.s_page = 0;
3742 #endif
3744 #ifdef COFF_WITH_PE
3745 section.s_paddr = 0;
3746 #endif
3747 #ifdef COFF_IMAGE_WITH_PE
3748 /* Reminder: s_paddr holds the virtual size of the section. */
3749 if (coff_section_data (abfd, current) != NULL
3750 && pei_section_data (abfd, current) != NULL)
3751 section.s_paddr = pei_section_data (abfd, current)->virt_size;
3752 else
3753 section.s_paddr = 0;
3754 #endif
3756 /* If this section has no size or is unloadable then the scnptr
3757 will be 0 too. */
3758 if (current->size == 0
3759 || (current->flags & (SEC_LOAD | SEC_HAS_CONTENTS)) == 0)
3760 section.s_scnptr = 0;
3761 else
3762 section.s_scnptr = current->filepos;
3764 section.s_relptr = current->rel_filepos;
3765 section.s_lnnoptr = current->line_filepos;
3766 section.s_nreloc = current->reloc_count;
3767 section.s_nlnno = current->lineno_count;
3768 #ifndef COFF_IMAGE_WITH_PE
3769 /* In PEI, relocs come in the .reloc section. */
3770 if (current->reloc_count != 0)
3771 hasrelocs = TRUE;
3772 #endif
3773 if (current->lineno_count != 0)
3774 haslinno = TRUE;
3775 #ifdef COFF_IMAGE_WITH_PE
3776 if ((current->flags & SEC_DEBUGGING) != 0
3777 && ! is_reloc_section)
3778 hasdebug = TRUE;
3779 #endif
3781 #ifdef RS6000COFF_C
3782 #ifndef XCOFF64
3783 /* Indicate the use of an XCOFF overflow section header. */
3784 if (current->reloc_count >= 0xffff || current->lineno_count >= 0xffff)
3786 section.s_nreloc = 0xffff;
3787 section.s_nlnno = 0xffff;
3789 #endif
3790 #endif
3792 section.s_flags = sec_to_styp_flags (current->name, current->flags);
3794 if (!strcmp (current->name, _TEXT))
3795 text_sec = current;
3796 else if (!strcmp (current->name, _DATA))
3797 data_sec = current;
3798 else if (!strcmp (current->name, _BSS))
3799 bss_sec = current;
3801 #ifdef I960
3802 section.s_align = (current->alignment_power
3803 ? 1 << current->alignment_power
3804 : 0);
3805 #endif
3806 #ifdef TIC80COFF
3807 /* TI COFF puts the alignment power in bits 8-11 of the flags. */
3808 section.s_flags |= (current->alignment_power & 0xF) << 8;
3809 #endif
3810 #ifdef COFF_ENCODE_ALIGNMENT
3811 COFF_ENCODE_ALIGNMENT(section, current->alignment_power);
3812 #endif
3814 #ifdef COFF_IMAGE_WITH_PE
3815 /* Suppress output of the sections if they are null. ld
3816 includes the bss and data sections even if there is no size
3817 assigned to them. NT loader doesn't like it if these section
3818 headers are included if the sections themselves are not
3819 needed. See also coff_compute_section_file_positions. */
3820 if (section.s_size == 0)
3821 internal_f.f_nscns--;
3822 else
3823 #endif
3825 SCNHDR buff;
3826 bfd_size_type amt = bfd_coff_scnhsz (abfd);
3828 if (coff_swap_scnhdr_out (abfd, &section, &buff) == 0
3829 || bfd_bwrite (& buff, amt, abfd) != amt)
3830 return FALSE;
3833 #ifdef COFF_WITH_PE
3834 /* PE stores COMDAT section information in the symbol table. If
3835 this section is supposed to have some COMDAT info, track down
3836 the symbol in the symbol table and modify it. */
3837 if ((current->flags & SEC_LINK_ONCE) != 0)
3839 unsigned int i, count;
3840 asymbol **psym;
3841 coff_symbol_type *csym = NULL;
3842 asymbol **psymsec;
3844 psymsec = NULL;
3845 count = bfd_get_symcount (abfd);
3846 for (i = 0, psym = abfd->outsymbols; i < count; i++, psym++)
3848 if ((*psym)->section != current)
3849 continue;
3851 /* Remember the location of the first symbol in this
3852 section. */
3853 if (psymsec == NULL)
3854 psymsec = psym;
3856 /* See if this is the section symbol. */
3857 if (strcmp ((*psym)->name, current->name) == 0)
3859 csym = coff_symbol_from (abfd, *psym);
3860 if (csym == NULL
3861 || csym->native == NULL
3862 || csym->native->u.syment.n_numaux < 1
3863 || csym->native->u.syment.n_sclass != C_STAT
3864 || csym->native->u.syment.n_type != T_NULL)
3865 continue;
3867 /* Here *PSYM is the section symbol for CURRENT. */
3869 break;
3873 /* Did we find it?
3874 Note that we might not if we're converting the file from
3875 some other object file format. */
3876 if (i < count)
3878 combined_entry_type *aux;
3880 /* We don't touch the x_checksum field. The
3881 x_associated field is not currently supported. */
3883 aux = csym->native + 1;
3884 switch (current->flags & SEC_LINK_DUPLICATES)
3886 case SEC_LINK_DUPLICATES_DISCARD:
3887 aux->u.auxent.x_scn.x_comdat = IMAGE_COMDAT_SELECT_ANY;
3888 break;
3890 case SEC_LINK_DUPLICATES_ONE_ONLY:
3891 aux->u.auxent.x_scn.x_comdat =
3892 IMAGE_COMDAT_SELECT_NODUPLICATES;
3893 break;
3895 case SEC_LINK_DUPLICATES_SAME_SIZE:
3896 aux->u.auxent.x_scn.x_comdat =
3897 IMAGE_COMDAT_SELECT_SAME_SIZE;
3898 break;
3900 case SEC_LINK_DUPLICATES_SAME_CONTENTS:
3901 aux->u.auxent.x_scn.x_comdat =
3902 IMAGE_COMDAT_SELECT_EXACT_MATCH;
3903 break;
3906 /* The COMDAT symbol must be the first symbol from this
3907 section in the symbol table. In order to make this
3908 work, we move the COMDAT symbol before the first
3909 symbol we found in the search above. It's OK to
3910 rearrange the symbol table at this point, because
3911 coff_renumber_symbols is going to rearrange it
3912 further and fix up all the aux entries. */
3913 if (psym != psymsec)
3915 asymbol *hold;
3916 asymbol **pcopy;
3918 hold = *psym;
3919 for (pcopy = psym; pcopy > psymsec; pcopy--)
3920 pcopy[0] = pcopy[-1];
3921 *psymsec = hold;
3925 #endif /* COFF_WITH_PE */
3928 #ifdef RS6000COFF_C
3929 #ifndef XCOFF64
3930 /* XCOFF handles overflows in the reloc and line number count fields
3931 by creating a new section header to hold the correct values. */
3932 for (current = abfd->sections; current != NULL; current = current->next)
3934 if (current->reloc_count >= 0xffff || current->lineno_count >= 0xffff)
3936 struct internal_scnhdr scnhdr;
3937 SCNHDR buff;
3938 bfd_size_type amt;
3940 internal_f.f_nscns++;
3941 strncpy (&(scnhdr.s_name[0]), current->name, 8);
3942 scnhdr.s_paddr = current->reloc_count;
3943 scnhdr.s_vaddr = current->lineno_count;
3944 scnhdr.s_size = 0;
3945 scnhdr.s_scnptr = 0;
3946 scnhdr.s_relptr = current->rel_filepos;
3947 scnhdr.s_lnnoptr = current->line_filepos;
3948 scnhdr.s_nreloc = current->target_index;
3949 scnhdr.s_nlnno = current->target_index;
3950 scnhdr.s_flags = STYP_OVRFLO;
3951 amt = bfd_coff_scnhsz (abfd);
3952 if (coff_swap_scnhdr_out (abfd, &scnhdr, &buff) == 0
3953 || bfd_bwrite (& buff, amt, abfd) != amt)
3954 return FALSE;
3957 #endif
3958 #endif
3960 /* OK, now set up the filehdr... */
3962 /* Don't include the internal abs section in the section count */
3964 /* We will NOT put a fucking timestamp in the header here. Every time you
3965 put it back, I will come in and take it out again. I'm sorry. This
3966 field does not belong here. We fill it with a 0 so it compares the
3967 same but is not a reasonable time. -- gnu@cygnus.com */
3968 internal_f.f_timdat = 0;
3969 internal_f.f_flags = 0;
3971 if (abfd->flags & EXEC_P)
3972 internal_f.f_opthdr = bfd_coff_aoutsz (abfd);
3973 else
3975 internal_f.f_opthdr = 0;
3976 #ifdef RS6000COFF_C
3977 #ifndef XCOFF64
3978 if (xcoff_data (abfd)->full_aouthdr)
3979 internal_f.f_opthdr = bfd_coff_aoutsz (abfd);
3980 else
3981 internal_f.f_opthdr = SMALL_AOUTSZ;
3982 #endif
3983 #endif
3986 if (!hasrelocs)
3987 internal_f.f_flags |= F_RELFLG;
3988 if (!haslinno)
3989 internal_f.f_flags |= F_LNNO;
3990 if (abfd->flags & EXEC_P)
3991 internal_f.f_flags |= F_EXEC;
3992 #ifdef COFF_IMAGE_WITH_PE
3993 if (! hasdebug)
3994 internal_f.f_flags |= IMAGE_FILE_DEBUG_STRIPPED;
3995 if (pe_data (abfd)->real_flags & IMAGE_FILE_LARGE_ADDRESS_AWARE)
3996 internal_f.f_flags |= IMAGE_FILE_LARGE_ADDRESS_AWARE;
3997 #endif
3999 #ifndef COFF_WITH_pex64
4000 #ifdef COFF_WITH_PE
4001 internal_f.f_flags |= IMAGE_FILE_32BIT_MACHINE;
4002 #else
4003 if (bfd_little_endian (abfd))
4004 internal_f.f_flags |= F_AR32WR;
4005 else
4006 internal_f.f_flags |= F_AR32W;
4007 #endif
4008 #endif
4010 #ifdef TI_TARGET_ID
4011 /* Target id is used in TI COFF v1 and later; COFF0 won't use this field,
4012 but it doesn't hurt to set it internally. */
4013 internal_f.f_target_id = TI_TARGET_ID;
4014 #endif
4015 #ifdef TIC80_TARGET_ID
4016 internal_f.f_target_id = TIC80_TARGET_ID;
4017 #endif
4019 /* FIXME, should do something about the other byte orders and
4020 architectures. */
4022 #ifdef RS6000COFF_C
4023 if ((abfd->flags & DYNAMIC) != 0)
4024 internal_f.f_flags |= F_SHROBJ;
4025 if (bfd_get_section_by_name (abfd, _LOADER) != NULL)
4026 internal_f.f_flags |= F_DYNLOAD;
4027 #endif
4029 memset (&internal_a, 0, sizeof internal_a);
4031 /* Set up architecture-dependent stuff. */
4033 unsigned int magic = 0;
4034 unsigned short flags = 0;
4036 coff_set_flags (abfd, &magic, &flags);
4037 internal_f.f_magic = magic;
4038 internal_f.f_flags |= flags;
4039 /* ...and the "opt"hdr... */
4041 #ifdef TICOFF_AOUT_MAGIC
4042 internal_a.magic = TICOFF_AOUT_MAGIC;
4043 #define __A_MAGIC_SET__
4044 #endif
4045 #ifdef TIC80COFF
4046 internal_a.magic = TIC80_ARCH_MAGIC;
4047 #define __A_MAGIC_SET__
4048 #endif /* TIC80 */
4049 #ifdef I860
4050 /* FIXME: What are the a.out magic numbers for the i860? */
4051 internal_a.magic = 0;
4052 #define __A_MAGIC_SET__
4053 #endif /* I860 */
4054 #ifdef I960
4055 internal_a.magic = (magic == I960ROMAGIC ? NMAGIC : OMAGIC);
4056 #define __A_MAGIC_SET__
4057 #endif /* I960 */
4058 #if M88
4059 #define __A_MAGIC_SET__
4060 internal_a.magic = PAGEMAGICBCS;
4061 #endif /* M88 */
4063 #if APOLLO_M68
4064 #define __A_MAGIC_SET__
4065 internal_a.magic = APOLLO_COFF_VERSION_NUMBER;
4066 #endif
4068 #if defined(M68) || defined(WE32K) || defined(M68K)
4069 #define __A_MAGIC_SET__
4070 #if defined(LYNXOS)
4071 internal_a.magic = LYNXCOFFMAGIC;
4072 #else
4073 #if defined(TARG_AUX)
4074 internal_a.magic = (abfd->flags & D_PAGED ? PAGEMAGICPEXECPAGED :
4075 abfd->flags & WP_TEXT ? PAGEMAGICPEXECSWAPPED :
4076 PAGEMAGICEXECSWAPPED);
4077 #else
4078 #if defined (PAGEMAGICPEXECPAGED)
4079 internal_a.magic = PAGEMAGICPEXECPAGED;
4080 #endif
4081 #endif /* TARG_AUX */
4082 #endif /* LYNXOS */
4083 #endif /* M68 || WE32K || M68K */
4085 #if defined(ARM)
4086 #define __A_MAGIC_SET__
4087 internal_a.magic = ZMAGIC;
4088 #endif
4090 #if defined(PPC_PE)
4091 #define __A_MAGIC_SET__
4092 internal_a.magic = IMAGE_NT_OPTIONAL_HDR_MAGIC;
4093 #endif
4095 #if defined MCORE_PE
4096 #define __A_MAGIC_SET__
4097 internal_a.magic = IMAGE_NT_OPTIONAL_HDR_MAGIC;
4098 #endif
4100 #if defined(I386)
4101 #define __A_MAGIC_SET__
4102 #if defined LYNXOS
4103 internal_a.magic = LYNXCOFFMAGIC;
4104 #elif defined AMD64
4105 internal_a.magic = IMAGE_NT_OPTIONAL_HDR64_MAGIC;
4106 #else
4107 internal_a.magic = ZMAGIC;
4108 #endif
4109 #endif /* I386 */
4111 #if defined(IA64)
4112 #define __A_MAGIC_SET__
4113 internal_a.magic = PE32PMAGIC;
4114 #endif /* IA64 */
4116 #if defined(SPARC)
4117 #define __A_MAGIC_SET__
4118 #if defined(LYNXOS)
4119 internal_a.magic = LYNXCOFFMAGIC;
4120 #endif /* LYNXOS */
4121 #endif /* SPARC */
4123 #ifdef RS6000COFF_C
4124 #define __A_MAGIC_SET__
4125 internal_a.magic = (abfd->flags & D_PAGED) ? RS6K_AOUTHDR_ZMAGIC :
4126 (abfd->flags & WP_TEXT) ? RS6K_AOUTHDR_NMAGIC :
4127 RS6K_AOUTHDR_OMAGIC;
4128 #endif
4130 #if defined(SH) && defined(COFF_WITH_PE)
4131 #define __A_MAGIC_SET__
4132 internal_a.magic = SH_PE_MAGIC;
4133 #endif
4135 #if defined(MIPS) && defined(COFF_WITH_PE)
4136 #define __A_MAGIC_SET__
4137 internal_a.magic = MIPS_PE_MAGIC;
4138 #endif
4140 #ifdef OR32
4141 #define __A_MAGIC_SET__
4142 internal_a.magic = NMAGIC; /* Assume separate i/d. */
4143 #endif
4145 #ifndef __A_MAGIC_SET__
4146 #include "Your aouthdr magic number is not being set!"
4147 #else
4148 #undef __A_MAGIC_SET__
4149 #endif
4152 /* FIXME: Does anybody ever set this to another value? */
4153 internal_a.vstamp = 0;
4155 /* Now should write relocs, strings, syms. */
4156 obj_sym_filepos (abfd) = sym_base;
4158 if (bfd_get_symcount (abfd) != 0)
4160 int firstundef;
4162 if (!coff_renumber_symbols (abfd, &firstundef))
4163 return FALSE;
4164 coff_mangle_symbols (abfd);
4165 if (! coff_write_symbols (abfd))
4166 return FALSE;
4167 if (! coff_write_linenumbers (abfd))
4168 return FALSE;
4169 if (! coff_write_relocs (abfd, firstundef))
4170 return FALSE;
4172 #ifdef COFF_LONG_SECTION_NAMES
4173 else if (long_section_names && ! obj_coff_strings_written (abfd))
4175 /* If we have long section names we have to write out the string
4176 table even if there are no symbols. */
4177 if (! coff_write_symbols (abfd))
4178 return FALSE;
4180 #endif
4181 #ifdef COFF_IMAGE_WITH_PE
4182 #ifdef PPC_PE
4183 else if ((abfd->flags & EXEC_P) != 0)
4185 bfd_byte b;
4187 /* PowerPC PE appears to require that all executable files be
4188 rounded up to the page size. */
4189 b = 0;
4190 if (bfd_seek (abfd,
4191 (file_ptr) BFD_ALIGN (sym_base, COFF_PAGE_SIZE) - 1,
4192 SEEK_SET) != 0
4193 || bfd_bwrite (&b, (bfd_size_type) 1, abfd) != 1)
4194 return FALSE;
4196 #endif
4197 #endif
4199 /* If bfd_get_symcount (abfd) != 0, then we are not using the COFF
4200 backend linker, and obj_raw_syment_count is not valid until after
4201 coff_write_symbols is called. */
4202 if (obj_raw_syment_count (abfd) != 0)
4204 internal_f.f_symptr = sym_base;
4205 #ifdef RS6000COFF_C
4206 /* AIX appears to require that F_RELFLG not be set if there are
4207 local symbols but no relocations. */
4208 internal_f.f_flags &=~ F_RELFLG;
4209 #endif
4211 else
4213 if (long_section_names)
4214 internal_f.f_symptr = sym_base;
4215 else
4216 internal_f.f_symptr = 0;
4217 internal_f.f_flags |= F_LSYMS;
4220 if (text_sec)
4222 internal_a.tsize = text_sec->size;
4223 internal_a.text_start = internal_a.tsize ? text_sec->vma : 0;
4225 if (data_sec)
4227 internal_a.dsize = data_sec->size;
4228 internal_a.data_start = internal_a.dsize ? data_sec->vma : 0;
4230 if (bss_sec)
4232 internal_a.bsize = bss_sec->size;
4233 if (internal_a.bsize && bss_sec->vma < internal_a.data_start)
4234 internal_a.data_start = bss_sec->vma;
4237 internal_a.entry = bfd_get_start_address (abfd);
4238 internal_f.f_nsyms = obj_raw_syment_count (abfd);
4240 #ifdef RS6000COFF_C
4241 if (xcoff_data (abfd)->full_aouthdr)
4243 bfd_vma toc;
4244 asection *loader_sec;
4246 internal_a.vstamp = 1;
4248 internal_a.o_snentry = xcoff_data (abfd)->snentry;
4249 if (internal_a.o_snentry == 0)
4250 internal_a.entry = (bfd_vma) -1;
4252 if (text_sec != NULL)
4254 internal_a.o_sntext = text_sec->target_index;
4255 internal_a.o_algntext = bfd_get_section_alignment (abfd, text_sec);
4257 else
4259 internal_a.o_sntext = 0;
4260 internal_a.o_algntext = 0;
4262 if (data_sec != NULL)
4264 internal_a.o_sndata = data_sec->target_index;
4265 internal_a.o_algndata = bfd_get_section_alignment (abfd, data_sec);
4267 else
4269 internal_a.o_sndata = 0;
4270 internal_a.o_algndata = 0;
4272 loader_sec = bfd_get_section_by_name (abfd, ".loader");
4273 if (loader_sec != NULL)
4274 internal_a.o_snloader = loader_sec->target_index;
4275 else
4276 internal_a.o_snloader = 0;
4277 if (bss_sec != NULL)
4278 internal_a.o_snbss = bss_sec->target_index;
4279 else
4280 internal_a.o_snbss = 0;
4282 toc = xcoff_data (abfd)->toc;
4283 internal_a.o_toc = toc;
4284 internal_a.o_sntoc = xcoff_data (abfd)->sntoc;
4286 internal_a.o_modtype = xcoff_data (abfd)->modtype;
4287 if (xcoff_data (abfd)->cputype != -1)
4288 internal_a.o_cputype = xcoff_data (abfd)->cputype;
4289 else
4291 switch (bfd_get_arch (abfd))
4293 case bfd_arch_rs6000:
4294 internal_a.o_cputype = 4;
4295 break;
4296 case bfd_arch_powerpc:
4297 if (bfd_get_mach (abfd) == bfd_mach_ppc)
4298 internal_a.o_cputype = 3;
4299 else
4300 internal_a.o_cputype = 1;
4301 break;
4302 default:
4303 abort ();
4306 internal_a.o_maxstack = xcoff_data (abfd)->maxstack;
4307 internal_a.o_maxdata = xcoff_data (abfd)->maxdata;
4309 #endif
4311 /* Now write them. */
4312 if (bfd_seek (abfd, (file_ptr) 0, SEEK_SET) != 0)
4313 return FALSE;
4316 char * buff;
4317 bfd_size_type amount = bfd_coff_filhsz (abfd);
4319 buff = (char *) bfd_malloc (amount);
4320 if (buff == NULL)
4321 return FALSE;
4323 bfd_coff_swap_filehdr_out (abfd, & internal_f, buff);
4324 amount = bfd_bwrite (buff, amount, abfd);
4326 free (buff);
4328 if (amount != bfd_coff_filhsz (abfd))
4329 return FALSE;
4332 if (abfd->flags & EXEC_P)
4334 /* Note that peicode.h fills in a PEAOUTHDR, not an AOUTHDR.
4335 include/coff/pe.h sets AOUTSZ == sizeof (PEAOUTHDR)). */
4336 char * buff;
4337 bfd_size_type amount = bfd_coff_aoutsz (abfd);
4339 buff = (char *) bfd_malloc (amount);
4340 if (buff == NULL)
4341 return FALSE;
4343 coff_swap_aouthdr_out (abfd, & internal_a, buff);
4344 amount = bfd_bwrite (buff, amount, abfd);
4346 free (buff);
4348 if (amount != bfd_coff_aoutsz (abfd))
4349 return FALSE;
4351 #ifdef COFF_IMAGE_WITH_PE
4352 if (! coff_apply_checksum (abfd))
4353 return FALSE;
4354 #endif
4356 #ifdef RS6000COFF_C
4357 else
4359 AOUTHDR buff;
4360 size_t size;
4362 /* XCOFF seems to always write at least a small a.out header. */
4363 coff_swap_aouthdr_out (abfd, & internal_a, & buff);
4364 if (xcoff_data (abfd)->full_aouthdr)
4365 size = bfd_coff_aoutsz (abfd);
4366 else
4367 size = SMALL_AOUTSZ;
4368 if (bfd_bwrite (& buff, (bfd_size_type) size, abfd) != size)
4369 return FALSE;
4371 #endif
4373 return TRUE;
4376 static bfd_boolean
4377 coff_set_section_contents (bfd * abfd,
4378 sec_ptr section,
4379 const void * location,
4380 file_ptr offset,
4381 bfd_size_type count)
4383 if (! abfd->output_has_begun) /* Set by bfd.c handler. */
4385 if (! coff_compute_section_file_positions (abfd))
4386 return FALSE;
4389 #if defined(_LIB) && !defined(TARG_AUX)
4390 /* The physical address field of a .lib section is used to hold the
4391 number of shared libraries in the section. This code counts the
4392 number of sections being written, and increments the lma field
4393 with the number.
4395 I have found no documentation on the contents of this section.
4396 Experimentation indicates that the section contains zero or more
4397 records, each of which has the following structure:
4399 - a (four byte) word holding the length of this record, in words,
4400 - a word that always seems to be set to "2",
4401 - the path to a shared library, null-terminated and then padded
4402 to a whole word boundary.
4404 bfd_assert calls have been added to alert if an attempt is made
4405 to write a section which doesn't follow these assumptions. The
4406 code has been tested on ISC 4.1 by me, and on SCO by Robert Lipe
4407 <robertl@arnet.com> (Thanks!).
4409 Gvran Uddeborg <gvran@uddeborg.pp.se>. */
4410 if (strcmp (section->name, _LIB) == 0)
4412 bfd_byte *rec, *recend;
4414 rec = (bfd_byte *) location;
4415 recend = rec + count;
4416 while (rec < recend)
4418 ++section->lma;
4419 rec += bfd_get_32 (abfd, rec) * 4;
4422 BFD_ASSERT (rec == recend);
4424 #endif
4426 /* Don't write out bss sections - one way to do this is to
4427 see if the filepos has not been set. */
4428 if (section->filepos == 0)
4429 return TRUE;
4431 if (bfd_seek (abfd, section->filepos + offset, SEEK_SET) != 0)
4432 return FALSE;
4434 if (count == 0)
4435 return TRUE;
4437 return bfd_bwrite (location, count, abfd) == count;
4440 static void *
4441 buy_and_read (bfd *abfd, file_ptr where, bfd_size_type size)
4443 void * area = bfd_alloc (abfd, size);
4445 if (!area)
4446 return (NULL);
4447 if (bfd_seek (abfd, where, SEEK_SET) != 0
4448 || bfd_bread (area, size, abfd) != size)
4449 return (NULL);
4450 return (area);
4454 SUBSUBSECTION
4455 Reading linenumbers
4457 Creating the linenumber table is done by reading in the entire
4458 coff linenumber table, and creating another table for internal use.
4460 A coff linenumber table is structured so that each function
4461 is marked as having a line number of 0. Each line within the
4462 function is an offset from the first line in the function. The
4463 base of the line number information for the table is stored in
4464 the symbol associated with the function.
4466 Note: The PE format uses line number 0 for a flag indicating a
4467 new source file.
4469 The information is copied from the external to the internal
4470 table, and each symbol which marks a function is marked by
4471 pointing its...
4473 How does this work ?
4476 static int
4477 coff_sort_func_alent (const void * arg1, const void * arg2)
4479 const alent *al1 = *(const alent **) arg1;
4480 const alent *al2 = *(const alent **) arg2;
4481 const coff_symbol_type *s1 = (const coff_symbol_type *) (al1->u.sym);
4482 const coff_symbol_type *s2 = (const coff_symbol_type *) (al2->u.sym);
4484 if (s1->symbol.value < s2->symbol.value)
4485 return -1;
4486 else if (s1->symbol.value > s2->symbol.value)
4487 return 1;
4489 return 0;
4492 static bfd_boolean
4493 coff_slurp_line_table (bfd *abfd, asection *asect)
4495 LINENO *native_lineno;
4496 alent *lineno_cache;
4497 bfd_size_type amt;
4498 unsigned int counter;
4499 alent *cache_ptr;
4500 bfd_vma prev_offset = 0;
4501 int ordered = 1;
4502 unsigned int nbr_func;
4503 LINENO *src;
4505 BFD_ASSERT (asect->lineno == NULL);
4507 amt = ((bfd_size_type) asect->lineno_count + 1) * sizeof (alent);
4508 lineno_cache = (alent *) bfd_alloc (abfd, amt);
4509 if (lineno_cache == NULL)
4510 return FALSE;
4512 amt = (bfd_size_type) bfd_coff_linesz (abfd) * asect->lineno_count;
4513 native_lineno = (LINENO *) buy_and_read (abfd, asect->line_filepos, amt);
4514 if (native_lineno == NULL)
4516 (*_bfd_error_handler)
4517 (_("%B: warning: line number table read failed"), abfd);
4518 bfd_release (abfd, lineno_cache);
4519 return FALSE;
4522 cache_ptr = lineno_cache;
4523 asect->lineno = lineno_cache;
4524 src = native_lineno;
4525 nbr_func = 0;
4527 for (counter = 0; counter < asect->lineno_count; counter++)
4529 struct internal_lineno dst;
4531 bfd_coff_swap_lineno_in (abfd, src, &dst);
4532 cache_ptr->line_number = dst.l_lnno;
4534 if (cache_ptr->line_number == 0)
4536 bfd_boolean warned;
4537 bfd_signed_vma symndx;
4538 coff_symbol_type *sym;
4540 nbr_func++;
4541 warned = FALSE;
4542 symndx = dst.l_addr.l_symndx;
4543 if (symndx < 0
4544 || (bfd_vma) symndx >= obj_raw_syment_count (abfd))
4546 (*_bfd_error_handler)
4547 (_("%B: warning: illegal symbol index %ld in line numbers"),
4548 abfd, (long) symndx);
4549 symndx = 0;
4550 warned = TRUE;
4553 /* FIXME: We should not be casting between ints and
4554 pointers like this. */
4555 sym = ((coff_symbol_type *)
4556 ((symndx + obj_raw_syments (abfd))
4557 ->u.syment._n._n_n._n_zeroes));
4558 cache_ptr->u.sym = (asymbol *) sym;
4559 if (sym->lineno != NULL && ! warned)
4560 (*_bfd_error_handler)
4561 (_("%B: warning: duplicate line number information for `%s'"),
4562 abfd, bfd_asymbol_name (&sym->symbol));
4564 sym->lineno = cache_ptr;
4565 if (sym->symbol.value < prev_offset)
4566 ordered = 0;
4567 prev_offset = sym->symbol.value;
4569 else
4570 cache_ptr->u.offset = dst.l_addr.l_paddr
4571 - bfd_section_vma (abfd, asect);
4573 cache_ptr++;
4574 src++;
4576 cache_ptr->line_number = 0;
4577 bfd_release (abfd, native_lineno);
4579 /* On some systems (eg AIX5.3) the lineno table may not be sorted. */
4580 if (!ordered)
4582 /* Sort the table. */
4583 alent **func_table;
4584 alent *n_lineno_cache;
4586 /* Create a table of functions. */
4587 func_table = (alent **) bfd_alloc (abfd, nbr_func * sizeof (alent *));
4588 if (func_table != NULL)
4590 alent **p = func_table;
4591 unsigned int i;
4593 for (i = 0; i < counter; i++)
4594 if (lineno_cache[i].line_number == 0)
4595 *p++ = &lineno_cache[i];
4597 /* Sort by functions. */
4598 qsort (func_table, nbr_func, sizeof (alent *), coff_sort_func_alent);
4600 /* Create the new sorted table. */
4601 amt = ((bfd_size_type) asect->lineno_count + 1) * sizeof (alent);
4602 n_lineno_cache = (alent *) bfd_alloc (abfd, amt);
4603 if (n_lineno_cache != NULL)
4605 alent *n_cache_ptr = n_lineno_cache;
4607 for (i = 0; i < nbr_func; i++)
4609 coff_symbol_type *sym;
4610 alent *old_ptr = func_table[i];
4612 /* Copy the function entry and update it. */
4613 *n_cache_ptr = *old_ptr;
4614 sym = (coff_symbol_type *)n_cache_ptr->u.sym;
4615 sym->lineno = n_cache_ptr;
4616 n_cache_ptr++;
4617 old_ptr++;
4619 /* Copy the line number entries. */
4620 while (old_ptr->line_number != 0)
4621 *n_cache_ptr++ = *old_ptr++;
4623 n_cache_ptr->line_number = 0;
4624 memcpy (lineno_cache, n_lineno_cache, amt);
4626 bfd_release (abfd, func_table);
4630 return TRUE;
4633 /* Slurp in the symbol table, converting it to generic form. Note
4634 that if coff_relocate_section is defined, the linker will read
4635 symbols via coff_link_add_symbols, rather than via this routine. */
4637 static bfd_boolean
4638 coff_slurp_symbol_table (bfd * abfd)
4640 combined_entry_type *native_symbols;
4641 coff_symbol_type *cached_area;
4642 unsigned int *table_ptr;
4643 bfd_size_type amt;
4644 unsigned int number_of_symbols = 0;
4646 if (obj_symbols (abfd))
4647 return TRUE;
4649 /* Read in the symbol table. */
4650 if ((native_symbols = coff_get_normalized_symtab (abfd)) == NULL)
4651 return FALSE;
4653 /* Allocate enough room for all the symbols in cached form. */
4654 amt = obj_raw_syment_count (abfd);
4655 amt *= sizeof (coff_symbol_type);
4656 cached_area = (coff_symbol_type *) bfd_alloc (abfd, amt);
4657 if (cached_area == NULL)
4658 return FALSE;
4660 amt = obj_raw_syment_count (abfd);
4661 amt *= sizeof (unsigned int);
4662 table_ptr = (unsigned int *) bfd_alloc (abfd, amt);
4664 if (table_ptr == NULL)
4665 return FALSE;
4666 else
4668 coff_symbol_type *dst = cached_area;
4669 unsigned int last_native_index = obj_raw_syment_count (abfd);
4670 unsigned int this_index = 0;
4672 while (this_index < last_native_index)
4674 combined_entry_type *src = native_symbols + this_index;
4675 table_ptr[this_index] = number_of_symbols;
4676 dst->symbol.the_bfd = abfd;
4678 dst->symbol.name = (char *) (src->u.syment._n._n_n._n_offset);
4679 /* We use the native name field to point to the cached field. */
4680 src->u.syment._n._n_n._n_zeroes = (bfd_hostptr_t) dst;
4681 dst->symbol.section = coff_section_from_bfd_index (abfd,
4682 src->u.syment.n_scnum);
4683 dst->symbol.flags = 0;
4684 dst->done_lineno = FALSE;
4686 switch (src->u.syment.n_sclass)
4688 #ifdef I960
4689 case C_LEAFEXT:
4690 /* Fall through to next case. */
4691 #endif
4693 case C_EXT:
4694 case C_WEAKEXT:
4695 #if defined ARM
4696 case C_THUMBEXT:
4697 case C_THUMBEXTFUNC:
4698 #endif
4699 #ifdef RS6000COFF_C
4700 case C_HIDEXT:
4701 #endif
4702 #ifdef C_SYSTEM
4703 case C_SYSTEM: /* System Wide variable. */
4704 #endif
4705 #ifdef COFF_WITH_PE
4706 /* In PE, 0x68 (104) denotes a section symbol. */
4707 case C_SECTION:
4708 /* In PE, 0x69 (105) denotes a weak external symbol. */
4709 case C_NT_WEAK:
4710 #endif
4711 switch (coff_classify_symbol (abfd, &src->u.syment))
4713 case COFF_SYMBOL_GLOBAL:
4714 dst->symbol.flags = BSF_EXPORT | BSF_GLOBAL;
4715 #if defined COFF_WITH_PE
4716 /* PE sets the symbol to a value relative to the
4717 start of the section. */
4718 dst->symbol.value = src->u.syment.n_value;
4719 #else
4720 dst->symbol.value = (src->u.syment.n_value
4721 - dst->symbol.section->vma);
4722 #endif
4723 if (ISFCN ((src->u.syment.n_type)))
4724 /* A function ext does not go at the end of a
4725 file. */
4726 dst->symbol.flags |= BSF_NOT_AT_END | BSF_FUNCTION;
4727 break;
4729 case COFF_SYMBOL_COMMON:
4730 dst->symbol.section = bfd_com_section_ptr;
4731 dst->symbol.value = src->u.syment.n_value;
4732 break;
4734 case COFF_SYMBOL_UNDEFINED:
4735 dst->symbol.section = bfd_und_section_ptr;
4736 dst->symbol.value = 0;
4737 break;
4739 case COFF_SYMBOL_PE_SECTION:
4740 dst->symbol.flags |= BSF_EXPORT | BSF_SECTION_SYM;
4741 dst->symbol.value = 0;
4742 break;
4744 case COFF_SYMBOL_LOCAL:
4745 dst->symbol.flags = BSF_LOCAL;
4746 #if defined COFF_WITH_PE
4747 /* PE sets the symbol to a value relative to the
4748 start of the section. */
4749 dst->symbol.value = src->u.syment.n_value;
4750 #else
4751 dst->symbol.value = (src->u.syment.n_value
4752 - dst->symbol.section->vma);
4753 #endif
4754 if (ISFCN ((src->u.syment.n_type)))
4755 dst->symbol.flags |= BSF_NOT_AT_END | BSF_FUNCTION;
4756 break;
4759 #ifdef RS6000COFF_C
4760 /* A symbol with a csect entry should not go at the end. */
4761 if (src->u.syment.n_numaux > 0)
4762 dst->symbol.flags |= BSF_NOT_AT_END;
4763 #endif
4765 #ifdef COFF_WITH_PE
4766 if (src->u.syment.n_sclass == C_NT_WEAK)
4767 dst->symbol.flags |= BSF_WEAK;
4769 if (src->u.syment.n_sclass == C_SECTION
4770 && src->u.syment.n_scnum > 0)
4771 dst->symbol.flags = BSF_LOCAL;
4772 #endif
4773 if (src->u.syment.n_sclass == C_WEAKEXT)
4774 dst->symbol.flags |= BSF_WEAK;
4776 break;
4778 case C_STAT: /* Static. */
4779 #ifdef I960
4780 case C_LEAFSTAT: /* Static leaf procedure. */
4781 #endif
4782 #if defined ARM
4783 case C_THUMBSTAT: /* Thumb static. */
4784 case C_THUMBLABEL: /* Thumb label. */
4785 case C_THUMBSTATFUNC:/* Thumb static function. */
4786 #endif
4787 #ifdef RS6000COFF_C
4788 case C_DWARF: /* A label in a dwarf section. */
4789 case C_INFO: /* A label in a comment section. */
4790 #endif
4791 case C_LABEL: /* Label. */
4792 if (src->u.syment.n_scnum == N_DEBUG)
4793 dst->symbol.flags = BSF_DEBUGGING;
4794 else
4795 dst->symbol.flags = BSF_LOCAL;
4797 /* Base the value as an index from the base of the
4798 section, if there is one. */
4799 if (dst->symbol.section)
4801 #if defined COFF_WITH_PE
4802 /* PE sets the symbol to a value relative to the
4803 start of the section. */
4804 dst->symbol.value = src->u.syment.n_value;
4805 #else
4806 dst->symbol.value = (src->u.syment.n_value
4807 - dst->symbol.section->vma);
4808 #endif
4810 else
4811 dst->symbol.value = src->u.syment.n_value;
4812 break;
4814 case C_MOS: /* Member of structure. */
4815 case C_EOS: /* End of structure. */
4816 case C_REGPARM: /* Register parameter. */
4817 case C_REG: /* register variable. */
4818 /* C_AUTOARG conflicts with TI COFF C_UEXT. */
4819 #if !defined (TIC80COFF) && !defined (TICOFF)
4820 #ifdef C_AUTOARG
4821 case C_AUTOARG: /* 960-specific storage class. */
4822 #endif
4823 #endif
4824 case C_TPDEF: /* Type definition. */
4825 case C_ARG:
4826 case C_AUTO: /* Automatic variable. */
4827 case C_FIELD: /* Bit field. */
4828 case C_ENTAG: /* Enumeration tag. */
4829 case C_MOE: /* Member of enumeration. */
4830 case C_MOU: /* Member of union. */
4831 case C_UNTAG: /* Union tag. */
4832 dst->symbol.flags = BSF_DEBUGGING;
4833 dst->symbol.value = (src->u.syment.n_value);
4834 break;
4836 case C_FILE: /* File name. */
4837 case C_STRTAG: /* Structure tag. */
4838 #ifdef RS6000COFF_C
4839 case C_GSYM:
4840 case C_LSYM:
4841 case C_PSYM:
4842 case C_RSYM:
4843 case C_RPSYM:
4844 case C_STSYM:
4845 case C_TCSYM:
4846 case C_BCOMM:
4847 case C_ECOML:
4848 case C_ECOMM:
4849 case C_DECL:
4850 case C_ENTRY:
4851 case C_FUN:
4852 case C_ESTAT:
4853 #endif
4854 dst->symbol.flags = BSF_DEBUGGING;
4855 dst->symbol.value = (src->u.syment.n_value);
4856 break;
4858 #ifdef RS6000COFF_C
4859 case C_BINCL: /* Beginning of include file. */
4860 case C_EINCL: /* Ending of include file. */
4861 /* The value is actually a pointer into the line numbers
4862 of the file. We locate the line number entry, and
4863 set the section to the section which contains it, and
4864 the value to the index in that section. */
4866 asection *sec;
4868 dst->symbol.flags = BSF_DEBUGGING;
4869 for (sec = abfd->sections; sec != NULL; sec = sec->next)
4870 if (sec->line_filepos <= (file_ptr) src->u.syment.n_value
4871 && ((file_ptr) (sec->line_filepos
4872 + sec->lineno_count * bfd_coff_linesz (abfd))
4873 > (file_ptr) src->u.syment.n_value))
4874 break;
4875 if (sec == NULL)
4876 dst->symbol.value = 0;
4877 else
4879 dst->symbol.section = sec;
4880 dst->symbol.value = ((src->u.syment.n_value
4881 - sec->line_filepos)
4882 / bfd_coff_linesz (abfd));
4883 src->fix_line = 1;
4886 break;
4888 case C_BSTAT:
4889 dst->symbol.flags = BSF_DEBUGGING;
4891 /* The value is actually a symbol index. Save a pointer
4892 to the symbol instead of the index. FIXME: This
4893 should use a union. */
4894 src->u.syment.n_value =
4895 (long) (intptr_t) (native_symbols + src->u.syment.n_value);
4896 dst->symbol.value = src->u.syment.n_value;
4897 src->fix_value = 1;
4898 break;
4899 #endif
4901 case C_BLOCK: /* ".bb" or ".eb". */
4902 case C_FCN: /* ".bf" or ".ef" (or PE ".lf"). */
4903 case C_EFCN: /* Physical end of function. */
4904 #if defined COFF_WITH_PE
4905 /* PE sets the symbol to a value relative to the start
4906 of the section. */
4907 dst->symbol.value = src->u.syment.n_value;
4908 if (strcmp (dst->symbol.name, ".bf") != 0)
4910 /* PE uses funny values for .ef and .lf; don't
4911 relocate them. */
4912 dst->symbol.flags = BSF_DEBUGGING;
4914 else
4915 dst->symbol.flags = BSF_DEBUGGING | BSF_DEBUGGING_RELOC;
4916 #else
4917 /* Base the value as an index from the base of the
4918 section. */
4919 dst->symbol.flags = BSF_LOCAL;
4920 dst->symbol.value = (src->u.syment.n_value
4921 - dst->symbol.section->vma);
4922 #endif
4923 break;
4925 case C_STATLAB: /* Static load time label. */
4926 dst->symbol.value = src->u.syment.n_value;
4927 dst->symbol.flags = BSF_GLOBAL;
4928 break;
4930 case C_NULL:
4931 /* PE DLLs sometimes have zeroed out symbols for some
4932 reason. Just ignore them without a warning. */
4933 if (src->u.syment.n_type == 0
4934 && src->u.syment.n_value == 0
4935 && src->u.syment.n_scnum == 0)
4936 break;
4937 #ifdef RS6000COFF_C
4938 /* XCOFF specific: deleted entry. */
4939 if (src->u.syment.n_value == C_NULL_VALUE)
4940 break;
4941 #endif
4942 /* Fall through. */
4943 case C_EXTDEF: /* External definition. */
4944 case C_ULABEL: /* Undefined label. */
4945 case C_USTATIC: /* Undefined static. */
4946 #ifndef COFF_WITH_PE
4947 /* C_LINE in regular coff is 0x68. NT has taken over this storage
4948 class to represent a section symbol. */
4949 case C_LINE: /* line # reformatted as symbol table entry. */
4950 /* NT uses 0x67 for a weak symbol, not C_ALIAS. */
4951 case C_ALIAS: /* Duplicate tag. */
4952 #endif
4953 /* New storage classes for TI COFF. */
4954 #if defined(TIC80COFF) || defined(TICOFF)
4955 case C_UEXT: /* Tentative external definition. */
4956 #endif
4957 case C_EXTLAB: /* External load time label. */
4958 case C_HIDDEN: /* Ext symbol in dmert public lib. */
4959 default:
4960 (*_bfd_error_handler)
4961 (_("%B: Unrecognized storage class %d for %s symbol `%s'"),
4962 abfd, src->u.syment.n_sclass,
4963 dst->symbol.section->name, dst->symbol.name);
4964 dst->symbol.flags = BSF_DEBUGGING;
4965 dst->symbol.value = (src->u.syment.n_value);
4966 break;
4969 dst->native = src;
4971 dst->symbol.udata.i = 0;
4972 dst->lineno = NULL;
4973 this_index += (src->u.syment.n_numaux) + 1;
4974 dst++;
4975 number_of_symbols++;
4979 obj_symbols (abfd) = cached_area;
4980 obj_raw_syments (abfd) = native_symbols;
4982 bfd_get_symcount (abfd) = number_of_symbols;
4983 obj_convert (abfd) = table_ptr;
4984 /* Slurp the line tables for each section too. */
4986 asection *p;
4988 p = abfd->sections;
4989 while (p)
4991 coff_slurp_line_table (abfd, p);
4992 p = p->next;
4996 return TRUE;
4999 /* Classify a COFF symbol. A couple of targets have globally visible
5000 symbols which are not class C_EXT, and this handles those. It also
5001 recognizes some special PE cases. */
5003 static enum coff_symbol_classification
5004 coff_classify_symbol (bfd *abfd,
5005 struct internal_syment *syment)
5007 /* FIXME: This partially duplicates the switch in
5008 coff_slurp_symbol_table. */
5009 switch (syment->n_sclass)
5011 case C_EXT:
5012 case C_WEAKEXT:
5013 #ifdef I960
5014 case C_LEAFEXT:
5015 #endif
5016 #ifdef ARM
5017 case C_THUMBEXT:
5018 case C_THUMBEXTFUNC:
5019 #endif
5020 #ifdef C_SYSTEM
5021 case C_SYSTEM:
5022 #endif
5023 #ifdef COFF_WITH_PE
5024 case C_NT_WEAK:
5025 #endif
5026 if (syment->n_scnum == 0)
5028 if (syment->n_value == 0)
5029 return COFF_SYMBOL_UNDEFINED;
5030 else
5031 return COFF_SYMBOL_COMMON;
5033 return COFF_SYMBOL_GLOBAL;
5035 default:
5036 break;
5039 #ifdef COFF_WITH_PE
5040 if (syment->n_sclass == C_STAT)
5042 if (syment->n_scnum == 0)
5043 /* The Microsoft compiler sometimes generates these if a
5044 small static function is inlined every time it is used.
5045 The function is discarded, but the symbol table entry
5046 remains. */
5047 return COFF_SYMBOL_LOCAL;
5049 #ifdef STRICT_PE_FORMAT
5050 /* This is correct for Microsoft generated objects, but it
5051 breaks gas generated objects. */
5052 if (syment->n_value == 0)
5054 asection *sec;
5055 char buf[SYMNMLEN + 1];
5057 sec = coff_section_from_bfd_index (abfd, syment->n_scnum);
5058 if (sec != NULL
5059 && (strcmp (bfd_get_section_name (abfd, sec),
5060 _bfd_coff_internal_syment_name (abfd, syment, buf))
5061 == 0))
5062 return COFF_SYMBOL_PE_SECTION;
5064 #endif
5066 return COFF_SYMBOL_LOCAL;
5069 if (syment->n_sclass == C_SECTION)
5071 /* In some cases in a DLL generated by the Microsoft linker, the
5072 n_value field will contain garbage. FIXME: This should
5073 probably be handled by the swapping function instead. */
5074 syment->n_value = 0;
5075 if (syment->n_scnum == 0)
5076 return COFF_SYMBOL_UNDEFINED;
5077 return COFF_SYMBOL_PE_SECTION;
5079 #endif /* COFF_WITH_PE */
5081 /* If it is not a global symbol, we presume it is a local symbol. */
5082 if (syment->n_scnum == 0)
5084 char buf[SYMNMLEN + 1];
5086 (*_bfd_error_handler)
5087 (_("warning: %B: local symbol `%s' has no section"),
5088 abfd, _bfd_coff_internal_syment_name (abfd, syment, buf));
5091 return COFF_SYMBOL_LOCAL;
5095 SUBSUBSECTION
5096 Reading relocations
5098 Coff relocations are easily transformed into the internal BFD form
5099 (@code{arelent}).
5101 Reading a coff relocation table is done in the following stages:
5103 o Read the entire coff relocation table into memory.
5105 o Process each relocation in turn; first swap it from the
5106 external to the internal form.
5108 o Turn the symbol referenced in the relocation's symbol index
5109 into a pointer into the canonical symbol table.
5110 This table is the same as the one returned by a call to
5111 @code{bfd_canonicalize_symtab}. The back end will call that
5112 routine and save the result if a canonicalization hasn't been done.
5114 o The reloc index is turned into a pointer to a howto
5115 structure, in a back end specific way. For instance, the 386
5116 and 960 use the @code{r_type} to directly produce an index
5117 into a howto table vector; the 88k subtracts a number from the
5118 @code{r_type} field and creates an addend field.
5121 #ifndef CALC_ADDEND
5122 #define CALC_ADDEND(abfd, ptr, reloc, cache_ptr) \
5124 coff_symbol_type *coffsym = NULL; \
5126 if (ptr && bfd_asymbol_bfd (ptr) != abfd) \
5127 coffsym = (obj_symbols (abfd) \
5128 + (cache_ptr->sym_ptr_ptr - symbols)); \
5129 else if (ptr) \
5130 coffsym = coff_symbol_from (abfd, ptr); \
5131 if (coffsym != NULL \
5132 && coffsym->native->u.syment.n_scnum == 0) \
5133 cache_ptr->addend = 0; \
5134 else if (ptr && bfd_asymbol_bfd (ptr) == abfd \
5135 && ptr->section != NULL) \
5136 cache_ptr->addend = - (ptr->section->vma + ptr->value); \
5137 else \
5138 cache_ptr->addend = 0; \
5140 #endif
5142 static bfd_boolean
5143 coff_slurp_reloc_table (bfd * abfd, sec_ptr asect, asymbol ** symbols)
5145 RELOC *native_relocs;
5146 arelent *reloc_cache;
5147 arelent *cache_ptr;
5148 unsigned int idx;
5149 bfd_size_type amt;
5151 if (asect->relocation)
5152 return TRUE;
5153 if (asect->reloc_count == 0)
5154 return TRUE;
5155 if (asect->flags & SEC_CONSTRUCTOR)
5156 return TRUE;
5157 if (!coff_slurp_symbol_table (abfd))
5158 return FALSE;
5160 amt = (bfd_size_type) bfd_coff_relsz (abfd) * asect->reloc_count;
5161 native_relocs = (RELOC *) buy_and_read (abfd, asect->rel_filepos, amt);
5162 amt = (bfd_size_type) asect->reloc_count * sizeof (arelent);
5163 reloc_cache = (arelent *) bfd_alloc (abfd, amt);
5165 if (reloc_cache == NULL || native_relocs == NULL)
5166 return FALSE;
5168 for (idx = 0; idx < asect->reloc_count; idx++)
5170 struct internal_reloc dst;
5171 struct external_reloc *src;
5172 #ifndef RELOC_PROCESSING
5173 asymbol *ptr;
5174 #endif
5176 cache_ptr = reloc_cache + idx;
5177 src = native_relocs + idx;
5179 dst.r_offset = 0;
5180 coff_swap_reloc_in (abfd, src, &dst);
5182 #ifdef RELOC_PROCESSING
5183 RELOC_PROCESSING (cache_ptr, &dst, symbols, abfd, asect);
5184 #else
5185 cache_ptr->address = dst.r_vaddr;
5187 if (dst.r_symndx != -1)
5189 if (dst.r_symndx < 0 || dst.r_symndx >= obj_conv_table_size (abfd))
5191 (*_bfd_error_handler)
5192 (_("%B: warning: illegal symbol index %ld in relocs"),
5193 abfd, (long) dst.r_symndx);
5194 cache_ptr->sym_ptr_ptr = bfd_abs_section_ptr->symbol_ptr_ptr;
5195 ptr = NULL;
5197 else
5199 cache_ptr->sym_ptr_ptr = (symbols
5200 + obj_convert (abfd)[dst.r_symndx]);
5201 ptr = *(cache_ptr->sym_ptr_ptr);
5204 else
5206 cache_ptr->sym_ptr_ptr = bfd_abs_section_ptr->symbol_ptr_ptr;
5207 ptr = NULL;
5210 /* The symbols definitions that we have read in have been
5211 relocated as if their sections started at 0. But the offsets
5212 refering to the symbols in the raw data have not been
5213 modified, so we have to have a negative addend to compensate.
5215 Note that symbols which used to be common must be left alone. */
5217 /* Calculate any reloc addend by looking at the symbol. */
5218 CALC_ADDEND (abfd, ptr, dst, cache_ptr);
5219 (void) ptr;
5221 cache_ptr->address -= asect->vma;
5222 /* !! cache_ptr->section = NULL;*/
5224 /* Fill in the cache_ptr->howto field from dst.r_type. */
5225 RTYPE2HOWTO (cache_ptr, &dst);
5226 #endif /* RELOC_PROCESSING */
5228 if (cache_ptr->howto == NULL)
5230 (*_bfd_error_handler)
5231 (_("%B: illegal relocation type %d at address 0x%lx"),
5232 abfd, dst.r_type, (long) dst.r_vaddr);
5233 bfd_set_error (bfd_error_bad_value);
5234 return FALSE;
5238 asect->relocation = reloc_cache;
5239 return TRUE;
5242 #ifndef coff_rtype_to_howto
5243 #ifdef RTYPE2HOWTO
5245 /* Get the howto structure for a reloc. This is only used if the file
5246 including this one defines coff_relocate_section to be
5247 _bfd_coff_generic_relocate_section, so it is OK if it does not
5248 always work. It is the responsibility of the including file to
5249 make sure it is reasonable if it is needed. */
5251 static reloc_howto_type *
5252 coff_rtype_to_howto (bfd *abfd ATTRIBUTE_UNUSED,
5253 asection *sec ATTRIBUTE_UNUSED,
5254 struct internal_reloc *rel,
5255 struct coff_link_hash_entry *h ATTRIBUTE_UNUSED,
5256 struct internal_syment *sym ATTRIBUTE_UNUSED,
5257 bfd_vma *addendp ATTRIBUTE_UNUSED)
5259 arelent genrel;
5261 genrel.howto = NULL;
5262 RTYPE2HOWTO (&genrel, rel);
5263 return genrel.howto;
5266 #else /* ! defined (RTYPE2HOWTO) */
5268 #define coff_rtype_to_howto NULL
5270 #endif /* ! defined (RTYPE2HOWTO) */
5271 #endif /* ! defined (coff_rtype_to_howto) */
5273 /* This is stupid. This function should be a boolean predicate. */
5275 static long
5276 coff_canonicalize_reloc (bfd * abfd,
5277 sec_ptr section,
5278 arelent ** relptr,
5279 asymbol ** symbols)
5281 arelent *tblptr = section->relocation;
5282 unsigned int count = 0;
5284 if (section->flags & SEC_CONSTRUCTOR)
5286 /* This section has relocs made up by us, they are not in the
5287 file, so take them out of their chain and place them into
5288 the data area provided. */
5289 arelent_chain *chain = section->constructor_chain;
5291 for (count = 0; count < section->reloc_count; count++)
5293 *relptr++ = &chain->relent;
5294 chain = chain->next;
5297 else
5299 if (! coff_slurp_reloc_table (abfd, section, symbols))
5300 return -1;
5302 tblptr = section->relocation;
5304 for (; count++ < section->reloc_count;)
5305 *relptr++ = tblptr++;
5307 *relptr = 0;
5308 return section->reloc_count;
5311 #ifndef coff_reloc16_estimate
5312 #define coff_reloc16_estimate dummy_reloc16_estimate
5314 static int
5315 dummy_reloc16_estimate (bfd *abfd ATTRIBUTE_UNUSED,
5316 asection *input_section ATTRIBUTE_UNUSED,
5317 arelent *reloc ATTRIBUTE_UNUSED,
5318 unsigned int shrink ATTRIBUTE_UNUSED,
5319 struct bfd_link_info *link_info ATTRIBUTE_UNUSED)
5321 abort ();
5322 return 0;
5325 #endif
5327 #ifndef coff_reloc16_extra_cases
5329 #define coff_reloc16_extra_cases dummy_reloc16_extra_cases
5331 /* This works even if abort is not declared in any header file. */
5333 static void
5334 dummy_reloc16_extra_cases (bfd *abfd ATTRIBUTE_UNUSED,
5335 struct bfd_link_info *link_info ATTRIBUTE_UNUSED,
5336 struct bfd_link_order *link_order ATTRIBUTE_UNUSED,
5337 arelent *reloc ATTRIBUTE_UNUSED,
5338 bfd_byte *data ATTRIBUTE_UNUSED,
5339 unsigned int *src_ptr ATTRIBUTE_UNUSED,
5340 unsigned int *dst_ptr ATTRIBUTE_UNUSED)
5342 abort ();
5344 #endif
5346 #ifndef coff_bfd_link_hash_table_free
5347 #define coff_bfd_link_hash_table_free _bfd_generic_link_hash_table_free
5348 #endif
5350 /* If coff_relocate_section is defined, we can use the optimized COFF
5351 backend linker. Otherwise we must continue to use the old linker. */
5353 #ifdef coff_relocate_section
5355 #ifndef coff_bfd_link_hash_table_create
5356 #define coff_bfd_link_hash_table_create _bfd_coff_link_hash_table_create
5357 #endif
5358 #ifndef coff_bfd_link_add_symbols
5359 #define coff_bfd_link_add_symbols _bfd_coff_link_add_symbols
5360 #endif
5361 #ifndef coff_bfd_final_link
5362 #define coff_bfd_final_link _bfd_coff_final_link
5363 #endif
5365 #else /* ! defined (coff_relocate_section) */
5367 #define coff_relocate_section NULL
5368 #ifndef coff_bfd_link_hash_table_create
5369 #define coff_bfd_link_hash_table_create _bfd_generic_link_hash_table_create
5370 #endif
5371 #ifndef coff_bfd_link_add_symbols
5372 #define coff_bfd_link_add_symbols _bfd_generic_link_add_symbols
5373 #endif
5374 #define coff_bfd_final_link _bfd_generic_final_link
5376 #endif /* ! defined (coff_relocate_section) */
5378 #define coff_bfd_link_just_syms _bfd_generic_link_just_syms
5379 #define coff_bfd_copy_link_hash_symbol_type \
5380 _bfd_generic_copy_link_hash_symbol_type
5381 #define coff_bfd_link_split_section _bfd_generic_link_split_section
5383 #ifndef coff_start_final_link
5384 #define coff_start_final_link NULL
5385 #endif
5387 #ifndef coff_adjust_symndx
5388 #define coff_adjust_symndx NULL
5389 #endif
5391 #ifndef coff_link_add_one_symbol
5392 #define coff_link_add_one_symbol _bfd_generic_link_add_one_symbol
5393 #endif
5395 #ifndef coff_link_output_has_begun
5397 static bfd_boolean
5398 coff_link_output_has_begun (bfd * abfd,
5399 struct coff_final_link_info * info ATTRIBUTE_UNUSED)
5401 return abfd->output_has_begun;
5403 #endif
5405 #ifndef coff_final_link_postscript
5407 static bfd_boolean
5408 coff_final_link_postscript (bfd * abfd ATTRIBUTE_UNUSED,
5409 struct coff_final_link_info * pfinfo ATTRIBUTE_UNUSED)
5411 return TRUE;
5413 #endif
5415 #ifndef coff_SWAP_aux_in
5416 #define coff_SWAP_aux_in coff_swap_aux_in
5417 #endif
5418 #ifndef coff_SWAP_sym_in
5419 #define coff_SWAP_sym_in coff_swap_sym_in
5420 #endif
5421 #ifndef coff_SWAP_lineno_in
5422 #define coff_SWAP_lineno_in coff_swap_lineno_in
5423 #endif
5424 #ifndef coff_SWAP_aux_out
5425 #define coff_SWAP_aux_out coff_swap_aux_out
5426 #endif
5427 #ifndef coff_SWAP_sym_out
5428 #define coff_SWAP_sym_out coff_swap_sym_out
5429 #endif
5430 #ifndef coff_SWAP_lineno_out
5431 #define coff_SWAP_lineno_out coff_swap_lineno_out
5432 #endif
5433 #ifndef coff_SWAP_reloc_out
5434 #define coff_SWAP_reloc_out coff_swap_reloc_out
5435 #endif
5436 #ifndef coff_SWAP_filehdr_out
5437 #define coff_SWAP_filehdr_out coff_swap_filehdr_out
5438 #endif
5439 #ifndef coff_SWAP_aouthdr_out
5440 #define coff_SWAP_aouthdr_out coff_swap_aouthdr_out
5441 #endif
5442 #ifndef coff_SWAP_scnhdr_out
5443 #define coff_SWAP_scnhdr_out coff_swap_scnhdr_out
5444 #endif
5445 #ifndef coff_SWAP_reloc_in
5446 #define coff_SWAP_reloc_in coff_swap_reloc_in
5447 #endif
5448 #ifndef coff_SWAP_filehdr_in
5449 #define coff_SWAP_filehdr_in coff_swap_filehdr_in
5450 #endif
5451 #ifndef coff_SWAP_aouthdr_in
5452 #define coff_SWAP_aouthdr_in coff_swap_aouthdr_in
5453 #endif
5454 #ifndef coff_SWAP_scnhdr_in
5455 #define coff_SWAP_scnhdr_in coff_swap_scnhdr_in
5456 #endif
5458 static bfd_coff_backend_data bfd_coff_std_swap_table ATTRIBUTE_UNUSED =
5460 coff_SWAP_aux_in, coff_SWAP_sym_in, coff_SWAP_lineno_in,
5461 coff_SWAP_aux_out, coff_SWAP_sym_out,
5462 coff_SWAP_lineno_out, coff_SWAP_reloc_out,
5463 coff_SWAP_filehdr_out, coff_SWAP_aouthdr_out,
5464 coff_SWAP_scnhdr_out,
5465 FILHSZ, AOUTSZ, SCNHSZ, SYMESZ, AUXESZ, RELSZ, LINESZ, FILNMLEN,
5466 #ifdef COFF_LONG_FILENAMES
5467 TRUE,
5468 #else
5469 FALSE,
5470 #endif
5471 COFF_DEFAULT_LONG_SECTION_NAMES,
5472 COFF_DEFAULT_SECTION_ALIGNMENT_POWER,
5473 #ifdef COFF_FORCE_SYMBOLS_IN_STRINGS
5474 TRUE,
5475 #else
5476 FALSE,
5477 #endif
5478 #ifdef COFF_DEBUG_STRING_WIDE_PREFIX
5480 #else
5482 #endif
5483 coff_SWAP_filehdr_in, coff_SWAP_aouthdr_in, coff_SWAP_scnhdr_in,
5484 coff_SWAP_reloc_in, coff_bad_format_hook, coff_set_arch_mach_hook,
5485 coff_mkobject_hook, styp_to_sec_flags, coff_set_alignment_hook,
5486 coff_slurp_symbol_table, symname_in_debug_hook, coff_pointerize_aux_hook,
5487 coff_print_aux, coff_reloc16_extra_cases, coff_reloc16_estimate,
5488 coff_classify_symbol, coff_compute_section_file_positions,
5489 coff_start_final_link, coff_relocate_section, coff_rtype_to_howto,
5490 coff_adjust_symndx, coff_link_add_one_symbol,
5491 coff_link_output_has_begun, coff_final_link_postscript,
5492 bfd_pe_print_pdata
5495 #ifdef TICOFF
5496 /* COFF0 differs in file/section header size and relocation entry size. */
5498 static bfd_coff_backend_data ticoff0_swap_table =
5500 coff_SWAP_aux_in, coff_SWAP_sym_in, coff_SWAP_lineno_in,
5501 coff_SWAP_aux_out, coff_SWAP_sym_out,
5502 coff_SWAP_lineno_out, coff_SWAP_reloc_out,
5503 coff_SWAP_filehdr_out, coff_SWAP_aouthdr_out,
5504 coff_SWAP_scnhdr_out,
5505 FILHSZ_V0, AOUTSZ, SCNHSZ_V01, SYMESZ, AUXESZ, RELSZ_V0, LINESZ, FILNMLEN,
5506 #ifdef COFF_LONG_FILENAMES
5507 TRUE,
5508 #else
5509 FALSE,
5510 #endif
5511 COFF_DEFAULT_LONG_SECTION_NAMES,
5512 COFF_DEFAULT_SECTION_ALIGNMENT_POWER,
5513 #ifdef COFF_FORCE_SYMBOLS_IN_STRINGS
5514 TRUE,
5515 #else
5516 FALSE,
5517 #endif
5518 #ifdef COFF_DEBUG_STRING_WIDE_PREFIX
5520 #else
5522 #endif
5523 coff_SWAP_filehdr_in, coff_SWAP_aouthdr_in, coff_SWAP_scnhdr_in,
5524 coff_SWAP_reloc_in, ticoff0_bad_format_hook, coff_set_arch_mach_hook,
5525 coff_mkobject_hook, styp_to_sec_flags, coff_set_alignment_hook,
5526 coff_slurp_symbol_table, symname_in_debug_hook, coff_pointerize_aux_hook,
5527 coff_print_aux, coff_reloc16_extra_cases, coff_reloc16_estimate,
5528 coff_classify_symbol, coff_compute_section_file_positions,
5529 coff_start_final_link, coff_relocate_section, coff_rtype_to_howto,
5530 coff_adjust_symndx, coff_link_add_one_symbol,
5531 coff_link_output_has_begun, coff_final_link_postscript,
5532 bfd_pe_print_pdata
5534 #endif
5536 #ifdef TICOFF
5537 /* COFF1 differs in section header size. */
5539 static bfd_coff_backend_data ticoff1_swap_table =
5541 coff_SWAP_aux_in, coff_SWAP_sym_in, coff_SWAP_lineno_in,
5542 coff_SWAP_aux_out, coff_SWAP_sym_out,
5543 coff_SWAP_lineno_out, coff_SWAP_reloc_out,
5544 coff_SWAP_filehdr_out, coff_SWAP_aouthdr_out,
5545 coff_SWAP_scnhdr_out,
5546 FILHSZ, AOUTSZ, SCNHSZ_V01, SYMESZ, AUXESZ, RELSZ, LINESZ, FILNMLEN,
5547 #ifdef COFF_LONG_FILENAMES
5548 TRUE,
5549 #else
5550 FALSE,
5551 #endif
5552 COFF_DEFAULT_LONG_SECTION_NAMES,
5553 COFF_DEFAULT_SECTION_ALIGNMENT_POWER,
5554 #ifdef COFF_FORCE_SYMBOLS_IN_STRINGS
5555 TRUE,
5556 #else
5557 FALSE,
5558 #endif
5559 #ifdef COFF_DEBUG_STRING_WIDE_PREFIX
5561 #else
5563 #endif
5564 coff_SWAP_filehdr_in, coff_SWAP_aouthdr_in, coff_SWAP_scnhdr_in,
5565 coff_SWAP_reloc_in, ticoff1_bad_format_hook, coff_set_arch_mach_hook,
5566 coff_mkobject_hook, styp_to_sec_flags, coff_set_alignment_hook,
5567 coff_slurp_symbol_table, symname_in_debug_hook, coff_pointerize_aux_hook,
5568 coff_print_aux, coff_reloc16_extra_cases, coff_reloc16_estimate,
5569 coff_classify_symbol, coff_compute_section_file_positions,
5570 coff_start_final_link, coff_relocate_section, coff_rtype_to_howto,
5571 coff_adjust_symndx, coff_link_add_one_symbol,
5572 coff_link_output_has_begun, coff_final_link_postscript,
5573 bfd_pe_print_pdata /* huh */
5575 #endif
5577 #ifndef coff_close_and_cleanup
5578 #define coff_close_and_cleanup _bfd_generic_close_and_cleanup
5579 #endif
5581 #ifndef coff_bfd_free_cached_info
5582 #define coff_bfd_free_cached_info _bfd_generic_bfd_free_cached_info
5583 #endif
5585 #ifndef coff_get_section_contents
5586 #define coff_get_section_contents _bfd_generic_get_section_contents
5587 #endif
5589 #ifndef coff_bfd_copy_private_symbol_data
5590 #define coff_bfd_copy_private_symbol_data _bfd_generic_bfd_copy_private_symbol_data
5591 #endif
5593 #ifndef coff_bfd_copy_private_header_data
5594 #define coff_bfd_copy_private_header_data _bfd_generic_bfd_copy_private_header_data
5595 #endif
5597 #ifndef coff_bfd_copy_private_section_data
5598 #define coff_bfd_copy_private_section_data _bfd_generic_bfd_copy_private_section_data
5599 #endif
5601 #ifndef coff_bfd_copy_private_bfd_data
5602 #define coff_bfd_copy_private_bfd_data _bfd_generic_bfd_copy_private_bfd_data
5603 #endif
5605 #ifndef coff_bfd_merge_private_bfd_data
5606 #define coff_bfd_merge_private_bfd_data _bfd_generic_bfd_merge_private_bfd_data
5607 #endif
5609 #ifndef coff_bfd_set_private_flags
5610 #define coff_bfd_set_private_flags _bfd_generic_bfd_set_private_flags
5611 #endif
5613 #ifndef coff_bfd_print_private_bfd_data
5614 #define coff_bfd_print_private_bfd_data _bfd_generic_bfd_print_private_bfd_data
5615 #endif
5617 #ifndef coff_bfd_is_local_label_name
5618 #define coff_bfd_is_local_label_name _bfd_coff_is_local_label_name
5619 #endif
5621 #ifndef coff_bfd_is_target_special_symbol
5622 #define coff_bfd_is_target_special_symbol ((bfd_boolean (*) (bfd *, asymbol *)) bfd_false)
5623 #endif
5625 #ifndef coff_read_minisymbols
5626 #define coff_read_minisymbols _bfd_generic_read_minisymbols
5627 #endif
5629 #ifndef coff_minisymbol_to_symbol
5630 #define coff_minisymbol_to_symbol _bfd_generic_minisymbol_to_symbol
5631 #endif
5633 /* The reloc lookup routine must be supplied by each individual COFF
5634 backend. */
5635 #ifndef coff_bfd_reloc_type_lookup
5636 #define coff_bfd_reloc_type_lookup _bfd_norelocs_bfd_reloc_type_lookup
5637 #endif
5638 #ifndef coff_bfd_reloc_name_lookup
5639 #define coff_bfd_reloc_name_lookup _bfd_norelocs_bfd_reloc_name_lookup
5640 #endif
5642 #ifndef coff_bfd_get_relocated_section_contents
5643 #define coff_bfd_get_relocated_section_contents \
5644 bfd_generic_get_relocated_section_contents
5645 #endif
5647 #ifndef coff_bfd_relax_section
5648 #define coff_bfd_relax_section bfd_generic_relax_section
5649 #endif
5651 #ifndef coff_bfd_gc_sections
5652 #define coff_bfd_gc_sections bfd_generic_gc_sections
5653 #endif
5655 #ifndef coff_bfd_merge_sections
5656 #define coff_bfd_merge_sections bfd_generic_merge_sections
5657 #endif
5659 #ifndef coff_bfd_is_group_section
5660 #define coff_bfd_is_group_section bfd_generic_is_group_section
5661 #endif
5663 #ifndef coff_bfd_discard_group
5664 #define coff_bfd_discard_group bfd_generic_discard_group
5665 #endif
5667 #ifndef coff_section_already_linked
5668 #define coff_section_already_linked \
5669 _bfd_generic_section_already_linked
5670 #endif
5672 #ifndef coff_bfd_define_common_symbol
5673 #define coff_bfd_define_common_symbol bfd_generic_define_common_symbol
5674 #endif
5676 #define CREATE_BIG_COFF_TARGET_VEC(VAR, NAME, EXTRA_O_FLAGS, EXTRA_S_FLAGS, UNDER, ALTERNATIVE, SWAP_TABLE) \
5677 const bfd_target VAR = \
5679 NAME , \
5680 bfd_target_coff_flavour, \
5681 BFD_ENDIAN_BIG, /* Data byte order is big. */ \
5682 BFD_ENDIAN_BIG, /* Header byte order is big. */ \
5683 /* object flags */ \
5684 (HAS_RELOC | EXEC_P | HAS_LINENO | HAS_DEBUG | \
5685 HAS_SYMS | HAS_LOCALS | WP_TEXT | EXTRA_O_FLAGS), \
5686 /* section flags */ \
5687 (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC | EXTRA_S_FLAGS),\
5688 UNDER, /* Leading symbol underscore. */ \
5689 '/', /* AR_pad_char. */ \
5690 15, /* AR_max_namelen. */ \
5691 0, /* match priority. */ \
5693 /* Data conversion functions. */ \
5694 bfd_getb64, bfd_getb_signed_64, bfd_putb64, \
5695 bfd_getb32, bfd_getb_signed_32, bfd_putb32, \
5696 bfd_getb16, bfd_getb_signed_16, bfd_putb16, \
5698 /* Header conversion functions. */ \
5699 bfd_getb64, bfd_getb_signed_64, bfd_putb64, \
5700 bfd_getb32, bfd_getb_signed_32, bfd_putb32, \
5701 bfd_getb16, bfd_getb_signed_16, bfd_putb16, \
5703 /* bfd_check_format. */ \
5704 { _bfd_dummy_target, coff_object_p, bfd_generic_archive_p, \
5705 _bfd_dummy_target }, \
5706 /* bfd_set_format. */ \
5707 { bfd_false, coff_mkobject, _bfd_generic_mkarchive, bfd_false }, \
5708 /* bfd_write_contents. */ \
5709 { bfd_false, coff_write_object_contents, _bfd_write_archive_contents, \
5710 bfd_false }, \
5712 BFD_JUMP_TABLE_GENERIC (coff), \
5713 BFD_JUMP_TABLE_COPY (coff), \
5714 BFD_JUMP_TABLE_CORE (_bfd_nocore), \
5715 BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_coff), \
5716 BFD_JUMP_TABLE_SYMBOLS (coff), \
5717 BFD_JUMP_TABLE_RELOCS (coff), \
5718 BFD_JUMP_TABLE_WRITE (coff), \
5719 BFD_JUMP_TABLE_LINK (coff), \
5720 BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic), \
5722 ALTERNATIVE, \
5724 SWAP_TABLE \
5727 #define CREATE_BIGHDR_COFF_TARGET_VEC(VAR, NAME, EXTRA_O_FLAGS, EXTRA_S_FLAGS, UNDER, ALTERNATIVE, SWAP_TABLE) \
5728 const bfd_target VAR = \
5730 NAME , \
5731 bfd_target_coff_flavour, \
5732 BFD_ENDIAN_LITTLE, /* Data byte order is little. */ \
5733 BFD_ENDIAN_BIG, /* Header byte order is big. */ \
5734 /* object flags */ \
5735 (HAS_RELOC | EXEC_P | HAS_LINENO | HAS_DEBUG | \
5736 HAS_SYMS | HAS_LOCALS | WP_TEXT | EXTRA_O_FLAGS), \
5737 /* section flags */ \
5738 (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC | EXTRA_S_FLAGS),\
5739 UNDER, /* Leading symbol underscore. */ \
5740 '/', /* AR_pad_char. */ \
5741 15, /* AR_max_namelen. */ \
5742 0, /* match priority. */ \
5744 /* Data conversion functions. */ \
5745 bfd_getb64, bfd_getb_signed_64, bfd_putb64, \
5746 bfd_getb32, bfd_getb_signed_32, bfd_putb32, \
5747 bfd_getb16, bfd_getb_signed_16, bfd_putb16, \
5749 /* Header conversion functions. */ \
5750 bfd_getb64, bfd_getb_signed_64, bfd_putb64, \
5751 bfd_getb32, bfd_getb_signed_32, bfd_putb32, \
5752 bfd_getb16, bfd_getb_signed_16, bfd_putb16, \
5754 /* bfd_check_format. */ \
5755 { _bfd_dummy_target, coff_object_p, bfd_generic_archive_p, \
5756 _bfd_dummy_target }, \
5757 /* bfd_set_format. */ \
5758 { bfd_false, coff_mkobject, _bfd_generic_mkarchive, bfd_false }, \
5759 /* bfd_write_contents. */ \
5760 { bfd_false, coff_write_object_contents, _bfd_write_archive_contents, \
5761 bfd_false }, \
5763 BFD_JUMP_TABLE_GENERIC (coff), \
5764 BFD_JUMP_TABLE_COPY (coff), \
5765 BFD_JUMP_TABLE_CORE (_bfd_nocore), \
5766 BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_coff), \
5767 BFD_JUMP_TABLE_SYMBOLS (coff), \
5768 BFD_JUMP_TABLE_RELOCS (coff), \
5769 BFD_JUMP_TABLE_WRITE (coff), \
5770 BFD_JUMP_TABLE_LINK (coff), \
5771 BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic), \
5773 ALTERNATIVE, \
5775 SWAP_TABLE \
5778 #define CREATE_LITTLE_COFF_TARGET_VEC(VAR, NAME, EXTRA_O_FLAGS, EXTRA_S_FLAGS, UNDER, ALTERNATIVE, SWAP_TABLE) \
5779 const bfd_target VAR = \
5781 NAME , \
5782 bfd_target_coff_flavour, \
5783 BFD_ENDIAN_LITTLE, /* Data byte order is little. */ \
5784 BFD_ENDIAN_LITTLE, /* Header byte order is little. */ \
5785 /* object flags */ \
5786 (HAS_RELOC | EXEC_P | HAS_LINENO | HAS_DEBUG | \
5787 HAS_SYMS | HAS_LOCALS | WP_TEXT | EXTRA_O_FLAGS), \
5788 /* section flags */ \
5789 (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC | EXTRA_S_FLAGS),\
5790 UNDER, /* Leading symbol underscore. */ \
5791 '/', /* AR_pad_char. */ \
5792 15, /* AR_max_namelen. */ \
5793 0, /* match priority. */ \
5795 /* Data conversion functions. */ \
5796 bfd_getl64, bfd_getl_signed_64, bfd_putl64, \
5797 bfd_getl32, bfd_getl_signed_32, bfd_putl32, \
5798 bfd_getl16, bfd_getl_signed_16, bfd_putl16, \
5799 /* Header conversion functions. */ \
5800 bfd_getl64, bfd_getl_signed_64, bfd_putl64, \
5801 bfd_getl32, bfd_getl_signed_32, bfd_putl32, \
5802 bfd_getl16, bfd_getl_signed_16, bfd_putl16, \
5803 /* bfd_check_format. */ \
5804 { _bfd_dummy_target, coff_object_p, bfd_generic_archive_p, \
5805 _bfd_dummy_target }, \
5806 /* bfd_set_format. */ \
5807 { bfd_false, coff_mkobject, _bfd_generic_mkarchive, bfd_false }, \
5808 /* bfd_write_contents. */ \
5809 { bfd_false, coff_write_object_contents, _bfd_write_archive_contents, \
5810 bfd_false }, \
5812 BFD_JUMP_TABLE_GENERIC (coff), \
5813 BFD_JUMP_TABLE_COPY (coff), \
5814 BFD_JUMP_TABLE_CORE (_bfd_nocore), \
5815 BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_coff), \
5816 BFD_JUMP_TABLE_SYMBOLS (coff), \
5817 BFD_JUMP_TABLE_RELOCS (coff), \
5818 BFD_JUMP_TABLE_WRITE (coff), \
5819 BFD_JUMP_TABLE_LINK (coff), \
5820 BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic), \
5822 ALTERNATIVE, \
5824 SWAP_TABLE \