OSDN Git Service

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