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