Prevent illegal memory accesses when attempting to read excessively large COFF line...
[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   if (asect->lineno_count > asect->size)
4582     {
4583       _bfd_error_handler
4584         (_("%B: warning: line number count (%#lx) exceeds section size (%#lx)"),
4585          abfd, (unsigned long) asect->lineno_count, (unsigned long) asect->size);
4586       return FALSE;
4587     }
4588
4589   amt = ((bfd_size_type) asect->lineno_count + 1) * sizeof (alent);
4590   lineno_cache = (alent *) bfd_alloc (abfd, amt);
4591   if (lineno_cache == NULL)
4592     return FALSE;
4593
4594   amt = (bfd_size_type) bfd_coff_linesz (abfd) * asect->lineno_count;
4595   native_lineno = (LINENO *) buy_and_read (abfd, asect->line_filepos, amt);
4596   if (native_lineno == NULL)
4597     {
4598       _bfd_error_handler
4599         (_("%B: warning: line number table read failed"), abfd);
4600       bfd_release (abfd, lineno_cache);
4601       return FALSE;
4602     }
4603
4604   cache_ptr = lineno_cache;
4605   asect->lineno = lineno_cache;
4606   src = native_lineno;
4607   nbr_func = 0;
4608   have_func = FALSE;
4609
4610   for (counter = 0; counter < asect->lineno_count; counter++, src++)
4611     {
4612       struct internal_lineno dst;
4613
4614       bfd_coff_swap_lineno_in (abfd, src, &dst);
4615       cache_ptr->line_number = dst.l_lnno;
4616       /* Appease memory checkers that get all excited about
4617          uninitialised memory when copying alents if u.offset is
4618          larger than u.sym.  (64-bit BFD on 32-bit host.)  */
4619       memset (&cache_ptr->u, 0, sizeof (cache_ptr->u));
4620
4621       if (cache_ptr->line_number == 0)
4622         {
4623           combined_entry_type * ent;
4624           unsigned long symndx;
4625           coff_symbol_type *sym;
4626
4627           have_func = FALSE;
4628           symndx = dst.l_addr.l_symndx;
4629           if (symndx >= obj_raw_syment_count (abfd))
4630             {
4631               _bfd_error_handler
4632                 /* xgettext:c-format */
4633                 (_("%B: warning: illegal symbol index 0x%lx in line number entry %d"),
4634                  abfd, symndx, counter);
4635               cache_ptr->line_number = -1;
4636               ret = FALSE;
4637               continue;
4638             }
4639
4640           ent = obj_raw_syments (abfd) + symndx;
4641           /* FIXME: We should not be casting between ints and
4642              pointers like this.  */
4643           if (! ent->is_sym)
4644             {
4645               _bfd_error_handler
4646                 /* xgettext:c-format */
4647                 (_("%B: warning: illegal symbol index 0x%lx in line number entry %d"),
4648                  abfd, symndx, counter);
4649               cache_ptr->line_number = -1;
4650               ret = FALSE;
4651               continue;
4652             }
4653           sym = (coff_symbol_type *) (ent->u.syment._n._n_n._n_zeroes);
4654
4655           /* PR 17512 file: 078-10659-0.004  */
4656           if (sym < obj_symbols (abfd)
4657               || sym >= obj_symbols (abfd) + bfd_get_symcount (abfd))
4658             {
4659               _bfd_error_handler
4660                 /* xgettext:c-format */
4661                 (_("%B: warning: illegal symbol in line number entry %d"),
4662                  abfd, counter);
4663               cache_ptr->line_number = -1;
4664               ret = FALSE;
4665               continue;
4666             }
4667
4668           have_func = TRUE;
4669           nbr_func++;
4670           cache_ptr->u.sym = (asymbol *) sym;
4671           if (sym->lineno != NULL)
4672             _bfd_error_handler
4673               /* xgettext:c-format */
4674               (_("%B: warning: duplicate line number information for `%s'"),
4675                abfd, bfd_asymbol_name (&sym->symbol));
4676
4677           sym->lineno = cache_ptr;
4678           if (sym->symbol.value < prev_offset)
4679             ordered = FALSE;
4680           prev_offset = sym->symbol.value;
4681         }
4682       else if (!have_func)
4683         /* Drop line information that has no associated function.
4684            PR 17521: file: 078-10659-0.004.  */
4685         continue;
4686       else
4687         cache_ptr->u.offset = (dst.l_addr.l_paddr
4688                                - bfd_section_vma (abfd, asect));
4689       cache_ptr++;
4690     }
4691
4692   asect->lineno_count = cache_ptr - lineno_cache;
4693   memset (cache_ptr, 0, sizeof (*cache_ptr));
4694   bfd_release (abfd, native_lineno);
4695
4696   /* On some systems (eg AIX5.3) the lineno table may not be sorted.  */
4697   if (!ordered)
4698     {
4699       /* Sort the table.  */
4700       alent **func_table;
4701       alent *n_lineno_cache;
4702
4703       /* Create a table of functions.  */
4704       func_table = (alent **) bfd_alloc (abfd, nbr_func * sizeof (alent *));
4705       if (func_table != NULL)
4706         {
4707           alent **p = func_table;
4708           unsigned int i;
4709
4710           for (i = 0; i < asect->lineno_count; i++)
4711             if (lineno_cache[i].line_number == 0)
4712               *p++ = &lineno_cache[i];
4713
4714           BFD_ASSERT ((unsigned int) (p - func_table) == nbr_func);
4715
4716           /* Sort by functions.  */
4717           qsort (func_table, nbr_func, sizeof (alent *), coff_sort_func_alent);
4718
4719           /* Create the new sorted table.  */
4720           amt = (bfd_size_type) asect->lineno_count * sizeof (alent);
4721           n_lineno_cache = (alent *) bfd_alloc (abfd, amt);
4722           if (n_lineno_cache != NULL)
4723             {
4724               alent *n_cache_ptr = n_lineno_cache;
4725
4726               for (i = 0; i < nbr_func; i++)
4727                 {
4728                   coff_symbol_type *sym;
4729                   alent *old_ptr = func_table[i];
4730
4731                   /* Update the function entry.  */
4732                   sym = (coff_symbol_type *) old_ptr->u.sym;
4733                   /* PR binutils/17512: Point the lineno to where
4734                      this entry will be after the memcpy below.  */
4735                   sym->lineno = lineno_cache + (n_cache_ptr - n_lineno_cache);
4736                   /* Copy the function and line number entries.  */
4737                   do
4738                     *n_cache_ptr++ = *old_ptr++;
4739                   while (old_ptr->line_number != 0);
4740                 }
4741               BFD_ASSERT ((bfd_size_type) (n_cache_ptr - n_lineno_cache) == (amt / sizeof (alent)));
4742
4743               memcpy (lineno_cache, n_lineno_cache, amt);
4744             }
4745           else
4746             ret = FALSE;
4747           bfd_release (abfd, func_table);
4748         }
4749       else
4750         ret = FALSE;
4751     }
4752
4753   return ret;
4754 }
4755
4756 /* Slurp in the symbol table, converting it to generic form.  Note
4757    that if coff_relocate_section is defined, the linker will read
4758    symbols via coff_link_add_symbols, rather than via this routine.  */
4759
4760 static bfd_boolean
4761 coff_slurp_symbol_table (bfd * abfd)
4762 {
4763   combined_entry_type *native_symbols;
4764   coff_symbol_type *cached_area;
4765   unsigned int *table_ptr;
4766   bfd_size_type amt;
4767   unsigned int number_of_symbols = 0;
4768   bfd_boolean ret = TRUE;
4769
4770   if (obj_symbols (abfd))
4771     return TRUE;
4772
4773   /* Read in the symbol table.  */
4774   if ((native_symbols = coff_get_normalized_symtab (abfd)) == NULL)
4775     return FALSE;
4776
4777   /* Allocate enough room for all the symbols in cached form.  */
4778   amt = obj_raw_syment_count (abfd);
4779   amt *= sizeof (coff_symbol_type);
4780   cached_area = (coff_symbol_type *) bfd_alloc (abfd, amt);
4781   if (cached_area == NULL)
4782     return FALSE;
4783
4784   amt = obj_raw_syment_count (abfd);
4785   amt *= sizeof (unsigned int);
4786   table_ptr = (unsigned int *) bfd_zalloc (abfd, amt);
4787
4788   if (table_ptr == NULL)
4789     return FALSE;
4790   else
4791     {
4792       coff_symbol_type *dst = cached_area;
4793       unsigned int last_native_index = obj_raw_syment_count (abfd);
4794       unsigned int this_index = 0;
4795
4796       while (this_index < last_native_index)
4797         {
4798           combined_entry_type *src = native_symbols + this_index;
4799           table_ptr[this_index] = number_of_symbols;
4800
4801           dst->symbol.the_bfd = abfd;
4802           BFD_ASSERT (src->is_sym);
4803           dst->symbol.name = (char *) (src->u.syment._n._n_n._n_offset);
4804           /* We use the native name field to point to the cached field.  */
4805           src->u.syment._n._n_n._n_zeroes = (bfd_hostptr_t) dst;
4806           dst->symbol.section = coff_section_from_bfd_index (abfd,
4807                                                      src->u.syment.n_scnum);
4808           dst->symbol.flags = 0;
4809           /* PR 17512: file: 079-7098-0.001:0.1.  */
4810           dst->symbol.value = 0;
4811           dst->done_lineno = FALSE;
4812
4813           switch (src->u.syment.n_sclass)
4814             {
4815 #ifdef I960
4816             case C_LEAFEXT:
4817               /* Fall through to next case.  */
4818 #endif
4819
4820             case C_EXT:
4821             case C_WEAKEXT:
4822 #if defined ARM
4823             case C_THUMBEXT:
4824             case C_THUMBEXTFUNC:
4825 #endif
4826 #ifdef RS6000COFF_C
4827             case C_HIDEXT:
4828 #if ! defined _AIX52 && ! defined AIX_WEAK_SUPPORT
4829             case C_AIX_WEAKEXT:
4830 #endif
4831 #endif
4832 #ifdef C_SYSTEM
4833             case C_SYSTEM:      /* System Wide variable.  */
4834 #endif
4835 #ifdef COFF_WITH_PE
4836             /* In PE, 0x68 (104) denotes a section symbol.  */
4837             case C_SECTION:
4838             /* In PE, 0x69 (105) denotes a weak external symbol.  */
4839             case C_NT_WEAK:
4840 #endif
4841               switch (coff_classify_symbol (abfd, &src->u.syment))
4842                 {
4843                 case COFF_SYMBOL_GLOBAL:
4844                   dst->symbol.flags = BSF_EXPORT | BSF_GLOBAL;
4845 #if defined COFF_WITH_PE
4846                   /* PE sets the symbol to a value relative to the
4847                      start of the section.  */
4848                   dst->symbol.value = src->u.syment.n_value;
4849 #else
4850                   dst->symbol.value = (src->u.syment.n_value
4851                                        - dst->symbol.section->vma);
4852 #endif
4853                   if (ISFCN ((src->u.syment.n_type)))
4854                     /* A function ext does not go at the end of a
4855                        file.  */
4856                     dst->symbol.flags |= BSF_NOT_AT_END | BSF_FUNCTION;
4857                   break;
4858
4859                 case COFF_SYMBOL_COMMON:
4860                   dst->symbol.section = bfd_com_section_ptr;
4861                   dst->symbol.value = src->u.syment.n_value;
4862                   break;
4863
4864                 case COFF_SYMBOL_UNDEFINED:
4865                   dst->symbol.section = bfd_und_section_ptr;
4866                   dst->symbol.value = 0;
4867                   break;
4868
4869                 case COFF_SYMBOL_PE_SECTION:
4870                   dst->symbol.flags |= BSF_EXPORT | BSF_SECTION_SYM;
4871                   dst->symbol.value = 0;
4872                   break;
4873
4874                 case COFF_SYMBOL_LOCAL:
4875                   dst->symbol.flags = BSF_LOCAL;
4876 #if defined COFF_WITH_PE
4877                   /* PE sets the symbol to a value relative to the
4878                      start of the section.  */
4879                   dst->symbol.value = src->u.syment.n_value;
4880 #else
4881                   dst->symbol.value = (src->u.syment.n_value
4882                                        - dst->symbol.section->vma);
4883 #endif
4884                   if (ISFCN ((src->u.syment.n_type)))
4885                     dst->symbol.flags |= BSF_NOT_AT_END | BSF_FUNCTION;
4886                   break;
4887                 }
4888
4889 #ifdef RS6000COFF_C
4890               /* A symbol with a csect entry should not go at the end.  */
4891               if (src->u.syment.n_numaux > 0)
4892                 dst->symbol.flags |= BSF_NOT_AT_END;
4893 #endif
4894
4895 #ifdef COFF_WITH_PE
4896               if (src->u.syment.n_sclass == C_NT_WEAK)
4897                 dst->symbol.flags |= BSF_WEAK;
4898
4899               if (src->u.syment.n_sclass == C_SECTION
4900                   && src->u.syment.n_scnum > 0)
4901                 dst->symbol.flags = BSF_LOCAL;
4902 #endif
4903               if (src->u.syment.n_sclass == C_WEAKEXT
4904 #ifdef RS6000COFF_C
4905                   || src->u.syment.n_sclass == C_AIX_WEAKEXT
4906 #endif
4907                   )
4908                 dst->symbol.flags |= BSF_WEAK;
4909
4910               break;
4911
4912             case C_STAT:         /* Static.  */
4913 #ifdef I960
4914             case C_LEAFSTAT:     /* Static leaf procedure.  */
4915 #endif
4916 #if defined ARM
4917             case C_THUMBSTAT:    /* Thumb static.  */
4918             case C_THUMBLABEL:   /* Thumb label.  */
4919             case C_THUMBSTATFUNC:/* Thumb static function.  */
4920 #endif
4921 #ifdef RS6000COFF_C
4922             case C_DWARF:        /* A label in a dwarf section.  */
4923             case C_INFO:         /* A label in a comment section.  */
4924 #endif
4925             case C_LABEL:        /* Label.  */
4926               if (src->u.syment.n_scnum == N_DEBUG)
4927                 dst->symbol.flags = BSF_DEBUGGING;
4928               else
4929                 dst->symbol.flags = BSF_LOCAL;
4930
4931               /* Base the value as an index from the base of the
4932                  section, if there is one.  */
4933               if (dst->symbol.section)
4934                 {
4935 #if defined COFF_WITH_PE
4936                   /* PE sets the symbol to a value relative to the
4937                      start of the section.  */
4938                   dst->symbol.value = src->u.syment.n_value;
4939 #else
4940                   dst->symbol.value = (src->u.syment.n_value
4941                                        - dst->symbol.section->vma);
4942 #endif
4943                 }
4944               else
4945                 dst->symbol.value = src->u.syment.n_value;
4946               break;
4947
4948             case C_MOS:         /* Member of structure.  */
4949             case C_EOS:         /* End of structure.  */
4950             case C_REGPARM:     /* Register parameter.  */
4951             case C_REG:         /* register variable.  */
4952               /* C_AUTOARG conflicts with TI COFF C_UEXT.  */
4953 #if !defined (TIC80COFF) && !defined (TICOFF)
4954 #ifdef C_AUTOARG
4955             case C_AUTOARG:     /* 960-specific storage class.  */
4956 #endif
4957 #endif
4958             case C_TPDEF:       /* Type definition.  */
4959             case C_ARG:
4960             case C_AUTO:        /* Automatic variable.  */
4961             case C_FIELD:       /* Bit field.  */
4962             case C_ENTAG:       /* Enumeration tag.  */
4963             case C_MOE:         /* Member of enumeration.  */
4964             case C_MOU:         /* Member of union.  */
4965             case C_UNTAG:       /* Union tag.  */
4966               dst->symbol.flags = BSF_DEBUGGING;
4967               dst->symbol.value = (src->u.syment.n_value);
4968               break;
4969
4970             case C_FILE:        /* File name.  */
4971             case C_STRTAG:      /* Structure tag.  */
4972 #ifdef RS6000COFF_C
4973             case C_GSYM:
4974             case C_LSYM:
4975             case C_PSYM:
4976             case C_RSYM:
4977             case C_RPSYM:
4978             case C_STSYM:
4979             case C_TCSYM:
4980             case C_BCOMM:
4981             case C_ECOML:
4982             case C_ECOMM:
4983             case C_DECL:
4984             case C_ENTRY:
4985             case C_FUN:
4986             case C_ESTAT:
4987 #endif
4988               dst->symbol.flags = BSF_DEBUGGING;
4989               dst->symbol.value = (src->u.syment.n_value);
4990               break;
4991
4992 #ifdef RS6000COFF_C
4993             case C_BINCL:       /* Beginning of include file.  */
4994             case C_EINCL:       /* Ending of include file.  */
4995               /* The value is actually a pointer into the line numbers
4996                  of the file.  We locate the line number entry, and
4997                  set the section to the section which contains it, and
4998                  the value to the index in that section.  */
4999               {
5000                 asection *sec;
5001
5002                 dst->symbol.flags = BSF_DEBUGGING;
5003                 for (sec = abfd->sections; sec != NULL; sec = sec->next)
5004                   if (sec->line_filepos <= (file_ptr) src->u.syment.n_value
5005                       && ((file_ptr) (sec->line_filepos
5006                                       + sec->lineno_count * bfd_coff_linesz (abfd))
5007                           > (file_ptr) src->u.syment.n_value))
5008                     break;
5009                 if (sec == NULL)
5010                   dst->symbol.value = 0;
5011                 else
5012                   {
5013                     dst->symbol.section = sec;
5014                     dst->symbol.value = ((src->u.syment.n_value
5015                                           - sec->line_filepos)
5016                                          / bfd_coff_linesz (abfd));
5017                     src->fix_line = 1;
5018                   }
5019               }
5020               break;
5021
5022             case C_BSTAT:
5023               dst->symbol.flags = BSF_DEBUGGING;
5024
5025               /* The value is actually a symbol index.  Save a pointer
5026                  to the symbol instead of the index.  FIXME: This
5027                  should use a union.  */
5028               src->u.syment.n_value =
5029                 (long) (intptr_t) (native_symbols + src->u.syment.n_value);
5030               dst->symbol.value = src->u.syment.n_value;
5031               src->fix_value = 1;
5032               break;
5033 #endif
5034
5035             case C_BLOCK:       /* ".bb" or ".eb".  */
5036             case C_FCN:         /* ".bf" or ".ef" (or PE ".lf").  */
5037             case C_EFCN:        /* Physical end of function.  */
5038 #if defined COFF_WITH_PE
5039               /* PE sets the symbol to a value relative to the start
5040                  of the section.  */
5041               dst->symbol.value = src->u.syment.n_value;
5042               if (strcmp (dst->symbol.name, ".bf") != 0)
5043                 {
5044                   /* PE uses funny values for .ef and .lf; don't
5045                      relocate them.  */
5046                   dst->symbol.flags = BSF_DEBUGGING;
5047                 }
5048               else
5049                 dst->symbol.flags = BSF_DEBUGGING | BSF_DEBUGGING_RELOC;
5050 #else
5051               /* Base the value as an index from the base of the
5052                  section.  */
5053               dst->symbol.flags = BSF_LOCAL;
5054               dst->symbol.value = (src->u.syment.n_value
5055                                    - dst->symbol.section->vma);
5056 #endif
5057               break;
5058
5059             case C_STATLAB:     /* Static load time label.  */
5060               dst->symbol.value = src->u.syment.n_value;
5061               dst->symbol.flags = BSF_GLOBAL;
5062               break;
5063
5064             case C_NULL:
5065               /* PE DLLs sometimes have zeroed out symbols for some
5066                  reason.  Just ignore them without a warning.  */
5067               if (src->u.syment.n_type == 0
5068                   && src->u.syment.n_value == 0
5069                   && src->u.syment.n_scnum == 0)
5070                 break;
5071 #ifdef RS6000COFF_C
5072               /* XCOFF specific: deleted entry.  */
5073               if (src->u.syment.n_value == C_NULL_VALUE)
5074                 break;
5075 #endif
5076               /* Fall through.  */
5077             case C_EXTDEF:      /* External definition.  */
5078             case C_ULABEL:      /* Undefined label.  */
5079             case C_USTATIC:     /* Undefined static.  */
5080 #ifndef COFF_WITH_PE
5081             /* C_LINE in regular coff is 0x68.  NT has taken over this storage
5082                class to represent a section symbol.  */
5083             case C_LINE:        /* line # reformatted as symbol table entry.  */
5084               /* NT uses 0x67 for a weak symbol, not C_ALIAS.  */
5085             case C_ALIAS:       /* Duplicate tag.  */
5086 #endif
5087               /* New storage classes for TI COFF.  */
5088 #if defined(TIC80COFF) || defined(TICOFF)
5089             case C_UEXT:        /* Tentative external definition.  */
5090 #endif
5091             case C_EXTLAB:      /* External load time label.  */
5092             default:
5093               _bfd_error_handler
5094                 /* xgettext:c-format */
5095                 (_("%B: Unrecognized storage class %d for %s symbol `%s'"),
5096                  abfd, src->u.syment.n_sclass,
5097                  dst->symbol.section->name, dst->symbol.name);
5098               ret = FALSE;
5099               /* Fall through.  */
5100             case C_HIDDEN:      /* Ext symbol in dmert public lib.  */
5101               /* PR 20722: These symbols can also be generated by
5102                  building DLLs with --gc-sections enabled.  */
5103               dst->symbol.flags = BSF_DEBUGGING;
5104               dst->symbol.value = (src->u.syment.n_value);
5105               break;
5106             }
5107
5108           dst->native = src;
5109           dst->symbol.udata.i = 0;
5110           dst->lineno = NULL;
5111
5112           this_index += (src->u.syment.n_numaux) + 1;
5113           dst++;
5114           number_of_symbols++;
5115         }
5116     }
5117
5118   obj_symbols (abfd) = cached_area;
5119   obj_raw_syments (abfd) = native_symbols;
5120
5121   bfd_get_symcount (abfd) = number_of_symbols;
5122   obj_convert (abfd) = table_ptr;
5123   /* Slurp the line tables for each section too.  */
5124   {
5125     asection *p;
5126
5127     p = abfd->sections;
5128     while (p)
5129       {
5130         if (! coff_slurp_line_table (abfd, p))
5131           return FALSE;
5132         p = p->next;
5133       }
5134   }
5135
5136   return ret;
5137 }
5138
5139 /* Classify a COFF symbol.  A couple of targets have globally visible
5140    symbols which are not class C_EXT, and this handles those.  It also
5141    recognizes some special PE cases.  */
5142
5143 static enum coff_symbol_classification
5144 coff_classify_symbol (bfd *abfd,
5145                       struct internal_syment *syment)
5146 {
5147   /* FIXME: This partially duplicates the switch in
5148      coff_slurp_symbol_table.  */
5149   switch (syment->n_sclass)
5150     {
5151     case C_EXT:
5152     case C_WEAKEXT:
5153 #ifdef I960
5154     case C_LEAFEXT:
5155 #endif
5156 #ifdef ARM
5157     case C_THUMBEXT:
5158     case C_THUMBEXTFUNC:
5159 #endif
5160 #ifdef C_SYSTEM
5161     case C_SYSTEM:
5162 #endif
5163 #ifdef COFF_WITH_PE
5164     case C_NT_WEAK:
5165 #endif
5166       if (syment->n_scnum == 0)
5167         {
5168           if (syment->n_value == 0)
5169             return COFF_SYMBOL_UNDEFINED;
5170           else
5171             return COFF_SYMBOL_COMMON;
5172         }
5173       return COFF_SYMBOL_GLOBAL;
5174
5175     default:
5176       break;
5177     }
5178
5179 #ifdef COFF_WITH_PE
5180   if (syment->n_sclass == C_STAT)
5181     {
5182       if (syment->n_scnum == 0)
5183         /* The Microsoft compiler sometimes generates these if a
5184            small static function is inlined every time it is used.
5185            The function is discarded, but the symbol table entry
5186            remains.  */
5187         return COFF_SYMBOL_LOCAL;
5188
5189 #ifdef STRICT_PE_FORMAT
5190       /* This is correct for Microsoft generated objects, but it
5191          breaks gas generated objects.  */
5192       if (syment->n_value == 0)
5193         {
5194           asection *sec;
5195           char * name;
5196           char buf[SYMNMLEN + 1];
5197
5198           name = _bfd_coff_internal_syment_name (abfd, syment, buf)
5199           sec = coff_section_from_bfd_index (abfd, syment->n_scnum);
5200           if (sec != NULL && name != NULL
5201               && (strcmp (bfd_get_section_name (abfd, sec), name) == 0))
5202             return COFF_SYMBOL_PE_SECTION;
5203         }
5204 #endif
5205
5206       return COFF_SYMBOL_LOCAL;
5207     }
5208
5209   if (syment->n_sclass == C_SECTION)
5210     {
5211       /* In some cases in a DLL generated by the Microsoft linker, the
5212          n_value field will contain garbage.  FIXME: This should
5213          probably be handled by the swapping function instead.  */
5214       syment->n_value = 0;
5215       if (syment->n_scnum == 0)
5216         return COFF_SYMBOL_UNDEFINED;
5217       return COFF_SYMBOL_PE_SECTION;
5218     }
5219 #endif /* COFF_WITH_PE */
5220
5221   /* If it is not a global symbol, we presume it is a local symbol.  */
5222   if (syment->n_scnum == 0)
5223     {
5224       char buf[SYMNMLEN + 1];
5225
5226       _bfd_error_handler
5227         /* xgettext:c-format */
5228         (_("warning: %B: local symbol `%s' has no section"),
5229          abfd, _bfd_coff_internal_syment_name (abfd, syment, buf));
5230     }
5231
5232   return COFF_SYMBOL_LOCAL;
5233 }
5234
5235 /*
5236 SUBSUBSECTION
5237         Reading relocations
5238
5239         Coff relocations are easily transformed into the internal BFD form
5240         (@code{arelent}).
5241
5242         Reading a coff relocation table is done in the following stages:
5243
5244         o Read the entire coff relocation table into memory.
5245
5246         o Process each relocation in turn; first swap it from the
5247         external to the internal form.
5248
5249         o Turn the symbol referenced in the relocation's symbol index
5250         into a pointer into the canonical symbol table.
5251         This table is the same as the one returned by a call to
5252         @code{bfd_canonicalize_symtab}. The back end will call that
5253         routine and save the result if a canonicalization hasn't been done.
5254
5255         o The reloc index is turned into a pointer to a howto
5256         structure, in a back end specific way. For instance, the 386
5257         and 960 use the @code{r_type} to directly produce an index
5258         into a howto table vector; the 88k subtracts a number from the
5259         @code{r_type} field and creates an addend field.
5260 */
5261
5262 #ifndef CALC_ADDEND
5263 #define CALC_ADDEND(abfd, ptr, reloc, cache_ptr)                \
5264   {                                                             \
5265     coff_symbol_type *coffsym = NULL;                           \
5266                                                                 \
5267     if (ptr && bfd_asymbol_bfd (ptr) != abfd)                   \
5268       coffsym = (obj_symbols (abfd)                             \
5269                  + (cache_ptr->sym_ptr_ptr - symbols));         \
5270     else if (ptr)                                               \
5271       coffsym = coff_symbol_from (ptr);                         \
5272     if (coffsym != NULL                                         \
5273         && coffsym->native->is_sym                              \
5274         && coffsym->native->u.syment.n_scnum == 0)              \
5275       cache_ptr->addend = 0;                                    \
5276     else if (ptr && bfd_asymbol_bfd (ptr) == abfd               \
5277              && ptr->section != NULL)                           \
5278       cache_ptr->addend = - (ptr->section->vma + ptr->value);   \
5279     else                                                        \
5280       cache_ptr->addend = 0;                                    \
5281   }
5282 #endif
5283
5284 static bfd_boolean
5285 coff_slurp_reloc_table (bfd * abfd, sec_ptr asect, asymbol ** symbols)
5286 {
5287   RELOC *native_relocs;
5288   arelent *reloc_cache;
5289   arelent *cache_ptr;
5290   unsigned int idx;
5291   bfd_size_type amt;
5292
5293   if (asect->relocation)
5294     return TRUE;
5295   if (asect->reloc_count == 0)
5296     return TRUE;
5297   if (asect->flags & SEC_CONSTRUCTOR)
5298     return TRUE;
5299   if (!coff_slurp_symbol_table (abfd))
5300     return FALSE;
5301
5302   amt = (bfd_size_type) bfd_coff_relsz (abfd) * asect->reloc_count;
5303   native_relocs = (RELOC *) buy_and_read (abfd, asect->rel_filepos, amt);
5304   amt = (bfd_size_type) asect->reloc_count * sizeof (arelent);
5305   reloc_cache = (arelent *) bfd_alloc (abfd, amt);
5306
5307   if (reloc_cache == NULL || native_relocs == NULL)
5308     return FALSE;
5309
5310   for (idx = 0; idx < asect->reloc_count; idx++)
5311     {
5312       struct internal_reloc dst;
5313       struct external_reloc *src;
5314 #ifndef RELOC_PROCESSING
5315       asymbol *ptr;
5316 #endif
5317
5318       cache_ptr = reloc_cache + idx;
5319       src = native_relocs + idx;
5320
5321       dst.r_offset = 0;
5322       coff_swap_reloc_in (abfd, src, &dst);
5323
5324 #ifdef RELOC_PROCESSING
5325       RELOC_PROCESSING (cache_ptr, &dst, symbols, abfd, asect);
5326 #else
5327       cache_ptr->address = dst.r_vaddr;
5328
5329       if (dst.r_symndx != -1)
5330         {
5331           if (dst.r_symndx < 0 || dst.r_symndx >= obj_conv_table_size (abfd))
5332             {
5333               _bfd_error_handler
5334                 /* xgettext:c-format */
5335                 (_("%B: warning: illegal symbol index %ld in relocs"),
5336                  abfd, dst.r_symndx);
5337               cache_ptr->sym_ptr_ptr = bfd_abs_section_ptr->symbol_ptr_ptr;
5338               ptr = NULL;
5339             }
5340           else
5341             {
5342               cache_ptr->sym_ptr_ptr = (symbols
5343                                         + obj_convert (abfd)[dst.r_symndx]);
5344               ptr = *(cache_ptr->sym_ptr_ptr);
5345             }
5346         }
5347       else
5348         {
5349           cache_ptr->sym_ptr_ptr = bfd_abs_section_ptr->symbol_ptr_ptr;
5350           ptr = NULL;
5351         }
5352
5353       /* The symbols definitions that we have read in have been
5354          relocated as if their sections started at 0. But the offsets
5355          refering to the symbols in the raw data have not been
5356          modified, so we have to have a negative addend to compensate.
5357
5358          Note that symbols which used to be common must be left alone.  */
5359
5360       /* Calculate any reloc addend by looking at the symbol.  */
5361       CALC_ADDEND (abfd, ptr, dst, cache_ptr);
5362       (void) ptr;
5363
5364       cache_ptr->address -= asect->vma;
5365       /* !! cache_ptr->section = NULL;*/
5366
5367       /* Fill in the cache_ptr->howto field from dst.r_type.  */
5368       RTYPE2HOWTO (cache_ptr, &dst);
5369 #endif  /* RELOC_PROCESSING */
5370
5371       if (cache_ptr->howto == NULL)
5372         {
5373           _bfd_error_handler
5374             /* xgettext:c-format */
5375             (_("%B: illegal relocation type %d at address %#Lx"),
5376              abfd, dst.r_type, dst.r_vaddr);
5377           bfd_set_error (bfd_error_bad_value);
5378           return FALSE;
5379         }
5380     }
5381
5382   asect->relocation = reloc_cache;
5383   return TRUE;
5384 }
5385
5386 #ifndef coff_rtype_to_howto
5387 #ifdef RTYPE2HOWTO
5388
5389 /* Get the howto structure for a reloc.  This is only used if the file
5390    including this one defines coff_relocate_section to be
5391    _bfd_coff_generic_relocate_section, so it is OK if it does not
5392    always work.  It is the responsibility of the including file to
5393    make sure it is reasonable if it is needed.  */
5394
5395 static reloc_howto_type *
5396 coff_rtype_to_howto (bfd *abfd ATTRIBUTE_UNUSED,
5397                      asection *sec ATTRIBUTE_UNUSED,
5398                      struct internal_reloc *rel ATTRIBUTE_UNUSED,
5399                      struct coff_link_hash_entry *h ATTRIBUTE_UNUSED,
5400                      struct internal_syment *sym ATTRIBUTE_UNUSED,
5401                      bfd_vma *addendp ATTRIBUTE_UNUSED)
5402 {
5403   arelent genrel;
5404
5405   genrel.howto = NULL;
5406   RTYPE2HOWTO (&genrel, rel);
5407   return genrel.howto;
5408 }
5409
5410 #else /* ! defined (RTYPE2HOWTO) */
5411
5412 #define coff_rtype_to_howto NULL
5413
5414 #endif /* ! defined (RTYPE2HOWTO) */
5415 #endif /* ! defined (coff_rtype_to_howto) */
5416
5417 /* This is stupid.  This function should be a boolean predicate.  */
5418
5419 static long
5420 coff_canonicalize_reloc (bfd * abfd,
5421                          sec_ptr section,
5422                          arelent ** relptr,
5423                          asymbol ** symbols)
5424 {
5425   arelent *tblptr = section->relocation;
5426   unsigned int count = 0;
5427
5428   if (section->flags & SEC_CONSTRUCTOR)
5429     {
5430       /* This section has relocs made up by us, they are not in the
5431          file, so take them out of their chain and place them into
5432          the data area provided.  */
5433       arelent_chain *chain = section->constructor_chain;
5434
5435       for (count = 0; count < section->reloc_count; count++)
5436         {
5437           *relptr++ = &chain->relent;
5438           chain = chain->next;
5439         }
5440     }
5441   else
5442     {
5443       if (! coff_slurp_reloc_table (abfd, section, symbols))
5444         return -1;
5445
5446       tblptr = section->relocation;
5447
5448       for (; count++ < section->reloc_count;)
5449         *relptr++ = tblptr++;
5450     }
5451   *relptr = 0;
5452   return section->reloc_count;
5453 }
5454
5455 #ifndef coff_set_reloc
5456 #define coff_set_reloc _bfd_generic_set_reloc
5457 #endif
5458
5459 #ifndef coff_reloc16_estimate
5460 #define coff_reloc16_estimate dummy_reloc16_estimate
5461
5462 static int
5463 dummy_reloc16_estimate (bfd *abfd ATTRIBUTE_UNUSED,
5464                         asection *input_section ATTRIBUTE_UNUSED,
5465                         arelent *reloc ATTRIBUTE_UNUSED,
5466                         unsigned int shrink ATTRIBUTE_UNUSED,
5467                         struct bfd_link_info *link_info ATTRIBUTE_UNUSED)
5468 {
5469   abort ();
5470   return 0;
5471 }
5472
5473 #endif
5474
5475 #ifndef coff_reloc16_extra_cases
5476
5477 #define coff_reloc16_extra_cases dummy_reloc16_extra_cases
5478
5479 /* This works even if abort is not declared in any header file.  */
5480
5481 static void
5482 dummy_reloc16_extra_cases (bfd *abfd ATTRIBUTE_UNUSED,
5483                            struct bfd_link_info *link_info ATTRIBUTE_UNUSED,
5484                            struct bfd_link_order *link_order ATTRIBUTE_UNUSED,
5485                            arelent *reloc ATTRIBUTE_UNUSED,
5486                            bfd_byte *data ATTRIBUTE_UNUSED,
5487                            unsigned int *src_ptr ATTRIBUTE_UNUSED,
5488                            unsigned int *dst_ptr ATTRIBUTE_UNUSED)
5489 {
5490   abort ();
5491 }
5492 #endif
5493
5494 /* If coff_relocate_section is defined, we can use the optimized COFF
5495    backend linker.  Otherwise we must continue to use the old linker.  */
5496
5497 #ifdef coff_relocate_section
5498
5499 #ifndef coff_bfd_link_hash_table_create
5500 #define coff_bfd_link_hash_table_create _bfd_coff_link_hash_table_create
5501 #endif
5502 #ifndef coff_bfd_link_add_symbols
5503 #define coff_bfd_link_add_symbols _bfd_coff_link_add_symbols
5504 #endif
5505 #ifndef coff_bfd_final_link
5506 #define coff_bfd_final_link _bfd_coff_final_link
5507 #endif
5508
5509 #else /* ! defined (coff_relocate_section) */
5510
5511 #define coff_relocate_section NULL
5512 #ifndef coff_bfd_link_hash_table_create
5513 #define coff_bfd_link_hash_table_create _bfd_generic_link_hash_table_create
5514 #endif
5515 #ifndef coff_bfd_link_add_symbols
5516 #define coff_bfd_link_add_symbols _bfd_generic_link_add_symbols
5517 #endif
5518 #define coff_bfd_final_link _bfd_generic_final_link
5519
5520 #endif /* ! defined (coff_relocate_section) */
5521
5522 #define coff_bfd_link_just_syms      _bfd_generic_link_just_syms
5523 #define coff_bfd_copy_link_hash_symbol_type \
5524   _bfd_generic_copy_link_hash_symbol_type
5525 #define coff_bfd_link_split_section  _bfd_generic_link_split_section
5526
5527 #define coff_bfd_link_check_relocs   _bfd_generic_link_check_relocs
5528
5529 #ifndef coff_start_final_link
5530 #define coff_start_final_link NULL
5531 #endif
5532
5533 #ifndef coff_adjust_symndx
5534 #define coff_adjust_symndx NULL
5535 #endif
5536
5537 #ifndef coff_link_add_one_symbol
5538 #define coff_link_add_one_symbol _bfd_generic_link_add_one_symbol
5539 #endif
5540
5541 #ifndef coff_link_output_has_begun
5542
5543 static bfd_boolean
5544 coff_link_output_has_begun (bfd * abfd,
5545                             struct coff_final_link_info * info ATTRIBUTE_UNUSED)
5546 {
5547   return abfd->output_has_begun;
5548 }
5549 #endif
5550
5551 #ifndef coff_final_link_postscript
5552
5553 static bfd_boolean
5554 coff_final_link_postscript (bfd * abfd ATTRIBUTE_UNUSED,
5555                             struct coff_final_link_info * pfinfo ATTRIBUTE_UNUSED)
5556 {
5557   return TRUE;
5558 }
5559 #endif
5560
5561 #ifndef coff_SWAP_aux_in
5562 #define coff_SWAP_aux_in coff_swap_aux_in
5563 #endif
5564 #ifndef coff_SWAP_sym_in
5565 #define coff_SWAP_sym_in coff_swap_sym_in
5566 #endif
5567 #ifndef coff_SWAP_lineno_in
5568 #define coff_SWAP_lineno_in coff_swap_lineno_in
5569 #endif
5570 #ifndef coff_SWAP_aux_out
5571 #define coff_SWAP_aux_out coff_swap_aux_out
5572 #endif
5573 #ifndef coff_SWAP_sym_out
5574 #define coff_SWAP_sym_out coff_swap_sym_out
5575 #endif
5576 #ifndef coff_SWAP_lineno_out
5577 #define coff_SWAP_lineno_out coff_swap_lineno_out
5578 #endif
5579 #ifndef coff_SWAP_reloc_out
5580 #define coff_SWAP_reloc_out coff_swap_reloc_out
5581 #endif
5582 #ifndef coff_SWAP_filehdr_out
5583 #define coff_SWAP_filehdr_out coff_swap_filehdr_out
5584 #endif
5585 #ifndef coff_SWAP_aouthdr_out
5586 #define coff_SWAP_aouthdr_out coff_swap_aouthdr_out
5587 #endif
5588 #ifndef coff_SWAP_scnhdr_out
5589 #define coff_SWAP_scnhdr_out coff_swap_scnhdr_out
5590 #endif
5591 #ifndef coff_SWAP_reloc_in
5592 #define coff_SWAP_reloc_in coff_swap_reloc_in
5593 #endif
5594 #ifndef coff_SWAP_filehdr_in
5595 #define coff_SWAP_filehdr_in coff_swap_filehdr_in
5596 #endif
5597 #ifndef coff_SWAP_aouthdr_in
5598 #define coff_SWAP_aouthdr_in coff_swap_aouthdr_in
5599 #endif
5600 #ifndef coff_SWAP_scnhdr_in
5601 #define coff_SWAP_scnhdr_in coff_swap_scnhdr_in
5602 #endif
5603
5604 static bfd_coff_backend_data bfd_coff_std_swap_table ATTRIBUTE_UNUSED =
5605 {
5606   coff_SWAP_aux_in, coff_SWAP_sym_in, coff_SWAP_lineno_in,
5607   coff_SWAP_aux_out, coff_SWAP_sym_out,
5608   coff_SWAP_lineno_out, coff_SWAP_reloc_out,
5609   coff_SWAP_filehdr_out, coff_SWAP_aouthdr_out,
5610   coff_SWAP_scnhdr_out,
5611   FILHSZ, AOUTSZ, SCNHSZ, SYMESZ, AUXESZ, RELSZ, LINESZ, FILNMLEN,
5612 #ifdef COFF_LONG_FILENAMES
5613   TRUE,
5614 #else
5615   FALSE,
5616 #endif
5617   COFF_DEFAULT_LONG_SECTION_NAMES,
5618   COFF_DEFAULT_SECTION_ALIGNMENT_POWER,
5619 #ifdef COFF_FORCE_SYMBOLS_IN_STRINGS
5620   TRUE,
5621 #else
5622   FALSE,
5623 #endif
5624 #ifdef COFF_DEBUG_STRING_WIDE_PREFIX
5625   4,
5626 #else
5627   2,
5628 #endif
5629   32768,
5630   coff_SWAP_filehdr_in, coff_SWAP_aouthdr_in, coff_SWAP_scnhdr_in,
5631   coff_SWAP_reloc_in, coff_bad_format_hook, coff_set_arch_mach_hook,
5632   coff_mkobject_hook, styp_to_sec_flags, coff_set_alignment_hook,
5633   coff_slurp_symbol_table, symname_in_debug_hook, coff_pointerize_aux_hook,
5634   coff_print_aux, coff_reloc16_extra_cases, coff_reloc16_estimate,
5635   coff_classify_symbol, coff_compute_section_file_positions,
5636   coff_start_final_link, coff_relocate_section, coff_rtype_to_howto,
5637   coff_adjust_symndx, coff_link_add_one_symbol,
5638   coff_link_output_has_begun, coff_final_link_postscript,
5639   bfd_pe_print_pdata
5640 };
5641
5642 #ifdef TICOFF
5643 /* COFF0 differs in file/section header size and relocation entry size.  */
5644
5645 static bfd_coff_backend_data ticoff0_swap_table =
5646 {
5647   coff_SWAP_aux_in, coff_SWAP_sym_in, coff_SWAP_lineno_in,
5648   coff_SWAP_aux_out, coff_SWAP_sym_out,
5649   coff_SWAP_lineno_out, coff_SWAP_reloc_out,
5650   coff_SWAP_filehdr_out, coff_SWAP_aouthdr_out,
5651   coff_SWAP_scnhdr_out,
5652   FILHSZ_V0, AOUTSZ, SCNHSZ_V01, SYMESZ, AUXESZ, RELSZ_V0, LINESZ, FILNMLEN,
5653 #ifdef COFF_LONG_FILENAMES
5654   TRUE,
5655 #else
5656   FALSE,
5657 #endif
5658   COFF_DEFAULT_LONG_SECTION_NAMES,
5659   COFF_DEFAULT_SECTION_ALIGNMENT_POWER,
5660 #ifdef COFF_FORCE_SYMBOLS_IN_STRINGS
5661   TRUE,
5662 #else
5663   FALSE,
5664 #endif
5665 #ifdef COFF_DEBUG_STRING_WIDE_PREFIX
5666   4,
5667 #else
5668   2,
5669 #endif
5670   32768,
5671   coff_SWAP_filehdr_in, coff_SWAP_aouthdr_in, coff_SWAP_scnhdr_in,
5672   coff_SWAP_reloc_in, ticoff0_bad_format_hook, coff_set_arch_mach_hook,
5673   coff_mkobject_hook, styp_to_sec_flags, coff_set_alignment_hook,
5674   coff_slurp_symbol_table, symname_in_debug_hook, coff_pointerize_aux_hook,
5675   coff_print_aux, coff_reloc16_extra_cases, coff_reloc16_estimate,
5676   coff_classify_symbol, coff_compute_section_file_positions,
5677   coff_start_final_link, coff_relocate_section, coff_rtype_to_howto,
5678   coff_adjust_symndx, coff_link_add_one_symbol,
5679   coff_link_output_has_begun, coff_final_link_postscript,
5680   bfd_pe_print_pdata
5681 };
5682 #endif
5683
5684 #ifdef TICOFF
5685 /* COFF1 differs in section header size.  */
5686
5687 static bfd_coff_backend_data ticoff1_swap_table =
5688 {
5689   coff_SWAP_aux_in, coff_SWAP_sym_in, coff_SWAP_lineno_in,
5690   coff_SWAP_aux_out, coff_SWAP_sym_out,
5691   coff_SWAP_lineno_out, coff_SWAP_reloc_out,
5692   coff_SWAP_filehdr_out, coff_SWAP_aouthdr_out,
5693   coff_SWAP_scnhdr_out,
5694   FILHSZ, AOUTSZ, SCNHSZ_V01, SYMESZ, AUXESZ, RELSZ, LINESZ, FILNMLEN,
5695 #ifdef COFF_LONG_FILENAMES
5696   TRUE,
5697 #else
5698   FALSE,
5699 #endif
5700   COFF_DEFAULT_LONG_SECTION_NAMES,
5701   COFF_DEFAULT_SECTION_ALIGNMENT_POWER,
5702 #ifdef COFF_FORCE_SYMBOLS_IN_STRINGS
5703   TRUE,
5704 #else
5705   FALSE,
5706 #endif
5707 #ifdef COFF_DEBUG_STRING_WIDE_PREFIX
5708   4,
5709 #else
5710   2,
5711 #endif
5712   32768,
5713   coff_SWAP_filehdr_in, coff_SWAP_aouthdr_in, coff_SWAP_scnhdr_in,
5714   coff_SWAP_reloc_in, ticoff1_bad_format_hook, coff_set_arch_mach_hook,
5715   coff_mkobject_hook, styp_to_sec_flags, coff_set_alignment_hook,
5716   coff_slurp_symbol_table, symname_in_debug_hook, coff_pointerize_aux_hook,
5717   coff_print_aux, coff_reloc16_extra_cases, coff_reloc16_estimate,
5718   coff_classify_symbol, coff_compute_section_file_positions,
5719   coff_start_final_link, coff_relocate_section, coff_rtype_to_howto,
5720   coff_adjust_symndx, coff_link_add_one_symbol,
5721   coff_link_output_has_begun, coff_final_link_postscript,
5722   bfd_pe_print_pdata    /* huh */
5723 };
5724 #endif
5725
5726 #ifdef COFF_WITH_PE_BIGOBJ
5727 /* The UID for bigobj files.  */
5728
5729 static const char header_bigobj_classid[16] =
5730 {
5731   0xC7, 0xA1, 0xBA, 0xD1,
5732   0xEE, 0xBA,
5733   0xa9, 0x4b,
5734   0xAF, 0x20,
5735   0xFA, 0xF6, 0x6A, 0xA4, 0xDC, 0xB8
5736 };
5737
5738 /* Swap routines.  */
5739
5740 static void
5741 coff_bigobj_swap_filehdr_in (bfd * abfd, void * src, void * dst)
5742 {
5743   struct external_ANON_OBJECT_HEADER_BIGOBJ *filehdr_src =
5744     (struct external_ANON_OBJECT_HEADER_BIGOBJ *) src;
5745   struct internal_filehdr *filehdr_dst = (struct internal_filehdr *) dst;
5746
5747   filehdr_dst->f_magic  = H_GET_16 (abfd, filehdr_src->Machine);
5748   filehdr_dst->f_nscns  = H_GET_32 (abfd, filehdr_src->NumberOfSections);
5749   filehdr_dst->f_timdat = H_GET_32 (abfd, filehdr_src->TimeDateStamp);
5750   filehdr_dst->f_symptr =
5751     GET_FILEHDR_SYMPTR (abfd, filehdr_src->PointerToSymbolTable);
5752   filehdr_dst->f_nsyms  = H_GET_32 (abfd, filehdr_src->NumberOfSymbols);
5753   filehdr_dst->f_opthdr = 0;
5754   filehdr_dst->f_flags  = 0;
5755
5756   /* Check other magic numbers.  */
5757   if (H_GET_16 (abfd, filehdr_src->Sig1) != IMAGE_FILE_MACHINE_UNKNOWN
5758       || H_GET_16 (abfd, filehdr_src->Sig2) != 0xffff
5759       || H_GET_16 (abfd, filehdr_src->Version) != 2
5760       || memcmp (filehdr_src->ClassID, header_bigobj_classid, 16) != 0)
5761     filehdr_dst->f_opthdr = 0xffff;
5762
5763   /* Note that CLR metadata are ignored.  */
5764 }
5765
5766 static unsigned int
5767 coff_bigobj_swap_filehdr_out (bfd *abfd, void * in, void * out)
5768 {
5769   struct internal_filehdr *filehdr_in = (struct internal_filehdr *) in;
5770   struct external_ANON_OBJECT_HEADER_BIGOBJ *filehdr_out =
5771     (struct external_ANON_OBJECT_HEADER_BIGOBJ *) out;
5772
5773   memset (filehdr_out, 0, sizeof (*filehdr_out));
5774
5775   H_PUT_16 (abfd, IMAGE_FILE_MACHINE_UNKNOWN, filehdr_out->Sig1);
5776   H_PUT_16 (abfd, 0xffff, filehdr_out->Sig2);
5777   H_PUT_16 (abfd, 2, filehdr_out->Version);
5778   memcpy (filehdr_out->ClassID, header_bigobj_classid, 16);
5779   H_PUT_16 (abfd, filehdr_in->f_magic, filehdr_out->Machine);
5780   H_PUT_32 (abfd, filehdr_in->f_nscns, filehdr_out->NumberOfSections);
5781   H_PUT_32 (abfd, filehdr_in->f_timdat, filehdr_out->TimeDateStamp);
5782   PUT_FILEHDR_SYMPTR (abfd, filehdr_in->f_symptr,
5783                       filehdr_out->PointerToSymbolTable);
5784   H_PUT_32 (abfd, filehdr_in->f_nsyms, filehdr_out->NumberOfSymbols);
5785
5786   return bfd_coff_filhsz (abfd);
5787 }
5788
5789 static void
5790 coff_bigobj_swap_sym_in (bfd * abfd, void * ext1, void * in1)
5791 {
5792   SYMENT_BIGOBJ *ext = (SYMENT_BIGOBJ *) ext1;
5793   struct internal_syment *in = (struct internal_syment *) in1;
5794
5795   if (ext->e.e_name[0] == 0)
5796     {
5797       in->_n._n_n._n_zeroes = 0;
5798       in->_n._n_n._n_offset = H_GET_32 (abfd, ext->e.e.e_offset);
5799     }
5800   else
5801     {
5802 #if SYMNMLEN != E_SYMNMLEN
5803 #error we need to cope with truncating or extending SYMNMLEN
5804 #else
5805       memcpy (in->_n._n_name, ext->e.e_name, SYMNMLEN);
5806 #endif
5807     }
5808
5809   in->n_value = H_GET_32 (abfd, ext->e_value);
5810   BFD_ASSERT (sizeof (in->n_scnum) >= 4);
5811   in->n_scnum = H_GET_32 (abfd, ext->e_scnum);
5812   in->n_type = H_GET_16 (abfd, ext->e_type);
5813   in->n_sclass = H_GET_8 (abfd, ext->e_sclass);
5814   in->n_numaux = H_GET_8 (abfd, ext->e_numaux);
5815 }
5816
5817 static unsigned int
5818 coff_bigobj_swap_sym_out (bfd * abfd, void * inp, void * extp)
5819 {
5820   struct internal_syment *in = (struct internal_syment *) inp;
5821   SYMENT_BIGOBJ *ext = (SYMENT_BIGOBJ *) extp;
5822
5823   if (in->_n._n_name[0] == 0)
5824     {
5825       H_PUT_32 (abfd, 0, ext->e.e.e_zeroes);
5826       H_PUT_32 (abfd, in->_n._n_n._n_offset, ext->e.e.e_offset);
5827     }
5828   else
5829     {
5830 #if SYMNMLEN != E_SYMNMLEN
5831 #error we need to cope with truncating or extending SYMNMLEN
5832 #else
5833       memcpy (ext->e.e_name, in->_n._n_name, SYMNMLEN);
5834 #endif
5835     }
5836
5837   H_PUT_32 (abfd, in->n_value, ext->e_value);
5838   H_PUT_32 (abfd, in->n_scnum, ext->e_scnum);
5839
5840   H_PUT_16 (abfd, in->n_type, ext->e_type);
5841   H_PUT_8 (abfd, in->n_sclass, ext->e_sclass);
5842   H_PUT_8 (abfd, in->n_numaux, ext->e_numaux);
5843
5844   return SYMESZ_BIGOBJ;
5845 }
5846
5847 static void
5848 coff_bigobj_swap_aux_in (bfd *abfd,
5849                          void * ext1,
5850                          int type,
5851                          int in_class,
5852                          int indx,
5853                          int numaux,
5854                          void * in1)
5855 {
5856   AUXENT_BIGOBJ *ext = (AUXENT_BIGOBJ *) ext1;
5857   union internal_auxent *in = (union internal_auxent *) in1;
5858
5859   switch (in_class)
5860     {
5861     case C_FILE:
5862       if (numaux > 1)
5863         {
5864           if (indx == 0)
5865             memcpy (in->x_file.x_fname, ext->File.Name,
5866                     numaux * sizeof (AUXENT_BIGOBJ));
5867         }
5868       else
5869         memcpy (in->x_file.x_fname, ext->File.Name, sizeof (ext->File.Name));
5870       break;
5871
5872     case C_STAT:
5873     case C_LEAFSTAT:
5874     case C_HIDDEN:
5875       if (type == T_NULL)
5876         {
5877           in->x_scn.x_scnlen = H_GET_32 (abfd, ext->Section.Length);
5878           in->x_scn.x_nreloc =
5879             H_GET_16 (abfd, ext->Section.NumberOfRelocations);
5880           in->x_scn.x_nlinno =
5881             H_GET_16 (abfd, ext->Section.NumberOfLinenumbers);
5882           in->x_scn.x_checksum = H_GET_32 (abfd, ext->Section.Checksum);
5883           in->x_scn.x_associated = H_GET_16 (abfd, ext->Section.Number)
5884             | (H_GET_16 (abfd, ext->Section.HighNumber) << 16);
5885           in->x_scn.x_comdat = H_GET_8 (abfd, ext->Section.Selection);
5886           return;
5887         }
5888       break;
5889
5890     default:
5891       in->x_sym.x_tagndx.l = H_GET_32 (abfd, ext->Sym.WeakDefaultSymIndex);
5892       /* Characteristics is ignored.  */
5893       break;
5894     }
5895 }
5896
5897 static unsigned int
5898 coff_bigobj_swap_aux_out (bfd * abfd,
5899                           void * inp,
5900                           int type,
5901                           int in_class,
5902                           int indx ATTRIBUTE_UNUSED,
5903                           int numaux ATTRIBUTE_UNUSED,
5904                           void * extp)
5905 {
5906   union internal_auxent * in = (union internal_auxent *) inp;
5907   AUXENT_BIGOBJ *ext = (AUXENT_BIGOBJ *) extp;
5908
5909   memset (ext, 0, AUXESZ);
5910
5911   switch (in_class)
5912     {
5913     case C_FILE:
5914       memcpy (ext->File.Name, in->x_file.x_fname, sizeof (ext->File.Name));
5915
5916       return AUXESZ;
5917
5918     case C_STAT:
5919     case C_LEAFSTAT:
5920     case C_HIDDEN:
5921       if (type == T_NULL)
5922         {
5923           H_PUT_32 (abfd, in->x_scn.x_scnlen, ext->Section.Length);
5924           H_PUT_16 (abfd, in->x_scn.x_nreloc,
5925                     ext->Section.NumberOfRelocations);
5926           H_PUT_16 (abfd, in->x_scn.x_nlinno,
5927                     ext->Section.NumberOfLinenumbers);
5928           H_PUT_32 (abfd, in->x_scn.x_checksum, ext->Section.Checksum);
5929           H_PUT_16 (abfd, in->x_scn.x_associated & 0xffff,
5930                     ext->Section.Number);
5931           H_PUT_16 (abfd, (in->x_scn.x_associated >> 16),
5932                     ext->Section.HighNumber);
5933           H_PUT_8 (abfd, in->x_scn.x_comdat, ext->Section.Selection);
5934           return AUXESZ;
5935         }
5936       break;
5937     }
5938
5939   H_PUT_32 (abfd, in->x_sym.x_tagndx.l, ext->Sym.WeakDefaultSymIndex);
5940   H_PUT_32 (abfd, 1, ext->Sym.WeakSearchType);
5941
5942   return AUXESZ;
5943 }
5944
5945 static bfd_coff_backend_data bigobj_swap_table =
5946 {
5947   coff_bigobj_swap_aux_in, coff_bigobj_swap_sym_in, coff_SWAP_lineno_in,
5948   coff_bigobj_swap_aux_out, coff_bigobj_swap_sym_out,
5949   coff_SWAP_lineno_out, coff_SWAP_reloc_out,
5950   coff_bigobj_swap_filehdr_out, coff_SWAP_aouthdr_out,
5951   coff_SWAP_scnhdr_out,
5952   FILHSZ_BIGOBJ, AOUTSZ, SCNHSZ, SYMESZ_BIGOBJ, AUXESZ_BIGOBJ,
5953    RELSZ, LINESZ, FILNMLEN_BIGOBJ,
5954   TRUE,
5955   COFF_DEFAULT_LONG_SECTION_NAMES,
5956   COFF_DEFAULT_SECTION_ALIGNMENT_POWER,
5957   FALSE,
5958   2,
5959   1U << 31,
5960   coff_bigobj_swap_filehdr_in, coff_SWAP_aouthdr_in, coff_SWAP_scnhdr_in,
5961   coff_SWAP_reloc_in, coff_bad_format_hook, coff_set_arch_mach_hook,
5962   coff_mkobject_hook, styp_to_sec_flags, coff_set_alignment_hook,
5963   coff_slurp_symbol_table, symname_in_debug_hook, coff_pointerize_aux_hook,
5964   coff_print_aux, coff_reloc16_extra_cases, coff_reloc16_estimate,
5965   coff_classify_symbol, coff_compute_section_file_positions,
5966   coff_start_final_link, coff_relocate_section, coff_rtype_to_howto,
5967   coff_adjust_symndx, coff_link_add_one_symbol,
5968   coff_link_output_has_begun, coff_final_link_postscript,
5969   bfd_pe_print_pdata    /* huh */
5970 };
5971
5972 #endif /* COFF_WITH_PE_BIGOBJ */
5973
5974 #ifndef coff_close_and_cleanup
5975 #define coff_close_and_cleanup              _bfd_generic_close_and_cleanup
5976 #endif
5977
5978 #ifndef coff_bfd_free_cached_info
5979 #define coff_bfd_free_cached_info           _bfd_generic_bfd_free_cached_info
5980 #endif
5981
5982 #ifndef coff_get_section_contents
5983 #define coff_get_section_contents           _bfd_generic_get_section_contents
5984 #endif
5985
5986 #ifndef coff_bfd_copy_private_symbol_data
5987 #define coff_bfd_copy_private_symbol_data   _bfd_generic_bfd_copy_private_symbol_data
5988 #endif
5989
5990 #ifndef coff_bfd_copy_private_header_data
5991 #define coff_bfd_copy_private_header_data   _bfd_generic_bfd_copy_private_header_data
5992 #endif
5993
5994 #ifndef coff_bfd_copy_private_section_data
5995 #define coff_bfd_copy_private_section_data  _bfd_generic_bfd_copy_private_section_data
5996 #endif
5997
5998 #ifndef coff_bfd_copy_private_bfd_data
5999 #define coff_bfd_copy_private_bfd_data      _bfd_generic_bfd_copy_private_bfd_data
6000 #endif
6001
6002 #ifndef coff_bfd_merge_private_bfd_data
6003 #define coff_bfd_merge_private_bfd_data     _bfd_generic_bfd_merge_private_bfd_data
6004 #endif
6005
6006 #ifndef coff_bfd_set_private_flags
6007 #define coff_bfd_set_private_flags          _bfd_generic_bfd_set_private_flags
6008 #endif
6009
6010 #ifndef coff_bfd_print_private_bfd_data
6011 #define coff_bfd_print_private_bfd_data     _bfd_generic_bfd_print_private_bfd_data
6012 #endif
6013
6014 #ifndef coff_bfd_is_local_label_name
6015 #define coff_bfd_is_local_label_name        _bfd_coff_is_local_label_name
6016 #endif
6017
6018 #ifndef coff_bfd_is_target_special_symbol
6019 #define coff_bfd_is_target_special_symbol   ((bfd_boolean (*) (bfd *, asymbol *)) bfd_false)
6020 #endif
6021
6022 #ifndef coff_read_minisymbols
6023 #define coff_read_minisymbols               _bfd_generic_read_minisymbols
6024 #endif
6025
6026 #ifndef coff_minisymbol_to_symbol
6027 #define coff_minisymbol_to_symbol           _bfd_generic_minisymbol_to_symbol
6028 #endif
6029
6030 /* The reloc lookup routine must be supplied by each individual COFF
6031    backend.  */
6032 #ifndef coff_bfd_reloc_type_lookup
6033 #define coff_bfd_reloc_type_lookup          _bfd_norelocs_bfd_reloc_type_lookup
6034 #endif
6035 #ifndef coff_bfd_reloc_name_lookup
6036 #define coff_bfd_reloc_name_lookup    _bfd_norelocs_bfd_reloc_name_lookup
6037 #endif
6038
6039 #ifndef coff_bfd_get_relocated_section_contents
6040 #define coff_bfd_get_relocated_section_contents \
6041   bfd_generic_get_relocated_section_contents
6042 #endif
6043
6044 #ifndef coff_bfd_relax_section
6045 #define coff_bfd_relax_section              bfd_generic_relax_section
6046 #endif
6047
6048 #ifndef coff_bfd_gc_sections
6049 #define coff_bfd_gc_sections                bfd_coff_gc_sections
6050 #endif
6051
6052 #ifndef coff_bfd_lookup_section_flags
6053 #define coff_bfd_lookup_section_flags       bfd_generic_lookup_section_flags
6054 #endif
6055
6056 #ifndef coff_bfd_merge_sections
6057 #define coff_bfd_merge_sections             bfd_generic_merge_sections
6058 #endif
6059
6060 #ifndef coff_bfd_is_group_section
6061 #define coff_bfd_is_group_section           bfd_generic_is_group_section
6062 #endif
6063
6064 #ifndef coff_bfd_discard_group
6065 #define coff_bfd_discard_group              bfd_generic_discard_group
6066 #endif
6067
6068 #ifndef coff_section_already_linked
6069 #define coff_section_already_linked \
6070   _bfd_coff_section_already_linked
6071 #endif
6072
6073 #ifndef coff_bfd_define_common_symbol
6074 #define coff_bfd_define_common_symbol       bfd_generic_define_common_symbol
6075 #endif
6076
6077 #ifndef coff_bfd_define_start_stop
6078 #define coff_bfd_define_start_stop          bfd_generic_define_start_stop
6079 #endif
6080
6081 #define CREATE_BIG_COFF_TARGET_VEC(VAR, NAME, EXTRA_O_FLAGS, EXTRA_S_FLAGS, UNDER, ALTERNATIVE, SWAP_TABLE)     \
6082 const bfd_target VAR =                                                  \
6083 {                                                                       \
6084   NAME ,                                                                \
6085   bfd_target_coff_flavour,                                              \
6086   BFD_ENDIAN_BIG,               /* Data byte order is big.  */          \
6087   BFD_ENDIAN_BIG,               /* Header byte order is big.  */        \
6088   /* object flags */                                                    \
6089   (HAS_RELOC | EXEC_P | HAS_LINENO | HAS_DEBUG |                        \
6090    HAS_SYMS | HAS_LOCALS | WP_TEXT | EXTRA_O_FLAGS),                    \
6091   /* section flags */                                                   \
6092   (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC | EXTRA_S_FLAGS),\
6093   UNDER,                        /* Leading symbol underscore.  */       \
6094   '/',                          /* AR_pad_char.  */                     \
6095   15,                           /* AR_max_namelen.  */                  \
6096   0,                            /* match priority.  */                  \
6097                                                                         \
6098   /* Data conversion functions.  */                                     \
6099   bfd_getb64, bfd_getb_signed_64, bfd_putb64,                           \
6100   bfd_getb32, bfd_getb_signed_32, bfd_putb32,                           \
6101   bfd_getb16, bfd_getb_signed_16, bfd_putb16,                           \
6102                                                                         \
6103   /* Header conversion functions.  */                                   \
6104   bfd_getb64, bfd_getb_signed_64, bfd_putb64,                           \
6105   bfd_getb32, bfd_getb_signed_32, bfd_putb32,                           \
6106   bfd_getb16, bfd_getb_signed_16, bfd_putb16,                           \
6107                                                                         \
6108         /* bfd_check_format.  */                                        \
6109   { _bfd_dummy_target, coff_object_p, bfd_generic_archive_p,            \
6110     _bfd_dummy_target },                                                \
6111         /* bfd_set_format.  */                                          \
6112   { bfd_false, coff_mkobject, _bfd_generic_mkarchive, bfd_false },      \
6113         /* bfd_write_contents.  */                                      \
6114   { bfd_false, coff_write_object_contents, _bfd_write_archive_contents, \
6115     bfd_false },                                                        \
6116                                                                         \
6117   BFD_JUMP_TABLE_GENERIC (coff),                                        \
6118   BFD_JUMP_TABLE_COPY (coff),                                           \
6119   BFD_JUMP_TABLE_CORE (_bfd_nocore),                                    \
6120   BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_coff),                           \
6121   BFD_JUMP_TABLE_SYMBOLS (coff),                                        \
6122   BFD_JUMP_TABLE_RELOCS (coff),                                         \
6123   BFD_JUMP_TABLE_WRITE (coff),                                          \
6124   BFD_JUMP_TABLE_LINK (coff),                                           \
6125   BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic),                              \
6126                                                                         \
6127   ALTERNATIVE,                                                          \
6128                                                                         \
6129   SWAP_TABLE                                                            \
6130 };
6131
6132 #define CREATE_BIGHDR_COFF_TARGET_VEC(VAR, NAME, EXTRA_O_FLAGS, EXTRA_S_FLAGS, UNDER, ALTERNATIVE, SWAP_TABLE)  \
6133 const bfd_target VAR =                                                  \
6134 {                                                                       \
6135   NAME ,                                                                \
6136   bfd_target_coff_flavour,                                              \
6137   BFD_ENDIAN_LITTLE,            /* Data byte order is little.  */       \
6138   BFD_ENDIAN_BIG,               /* Header byte order is big.  */        \
6139   /* object flags */                                                    \
6140   (HAS_RELOC | EXEC_P | HAS_LINENO | HAS_DEBUG |                        \
6141    HAS_SYMS | HAS_LOCALS | WP_TEXT | EXTRA_O_FLAGS),                    \
6142   /* section flags */                                                   \
6143   (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC | EXTRA_S_FLAGS),\
6144   UNDER,                        /* Leading symbol underscore.  */       \
6145   '/',                          /* AR_pad_char.  */                     \
6146   15,                           /* AR_max_namelen.  */                  \
6147   0,                            /* match priority.  */                  \
6148                                                                         \
6149   /* Data conversion functions.  */                                     \
6150   bfd_getb64, bfd_getb_signed_64, bfd_putb64,                           \
6151   bfd_getb32, bfd_getb_signed_32, bfd_putb32,                           \
6152   bfd_getb16, bfd_getb_signed_16, bfd_putb16,                           \
6153                                                                         \
6154   /* Header conversion functions.  */                                   \
6155   bfd_getb64, bfd_getb_signed_64, bfd_putb64,                           \
6156   bfd_getb32, bfd_getb_signed_32, bfd_putb32,                           \
6157   bfd_getb16, bfd_getb_signed_16, bfd_putb16,                           \
6158                                                                         \
6159         /* bfd_check_format.  */                                        \
6160   { _bfd_dummy_target, coff_object_p, bfd_generic_archive_p,            \
6161     _bfd_dummy_target },                                                \
6162         /* bfd_set_format.  */                                          \
6163   { bfd_false, coff_mkobject, _bfd_generic_mkarchive, bfd_false },      \
6164         /* bfd_write_contents.  */                                      \
6165   { bfd_false, coff_write_object_contents, _bfd_write_archive_contents, \
6166     bfd_false },                                                        \
6167                                                                         \
6168   BFD_JUMP_TABLE_GENERIC (coff),                                        \
6169   BFD_JUMP_TABLE_COPY (coff),                                           \
6170   BFD_JUMP_TABLE_CORE (_bfd_nocore),                                    \
6171   BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_coff),                           \
6172   BFD_JUMP_TABLE_SYMBOLS (coff),                                        \
6173   BFD_JUMP_TABLE_RELOCS (coff),                                         \
6174   BFD_JUMP_TABLE_WRITE (coff),                                          \
6175   BFD_JUMP_TABLE_LINK (coff),                                           \
6176   BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic),                              \
6177                                                                         \
6178   ALTERNATIVE,                                                          \
6179                                                                         \
6180   SWAP_TABLE                                                            \
6181 };
6182
6183 #define CREATE_LITTLE_COFF_TARGET_VEC(VAR, NAME, EXTRA_O_FLAGS, EXTRA_S_FLAGS, UNDER, ALTERNATIVE, SWAP_TABLE)  \
6184 const bfd_target VAR =                                                  \
6185 {                                                                       \
6186   NAME ,                                                                \
6187   bfd_target_coff_flavour,                                              \
6188   BFD_ENDIAN_LITTLE,            /* Data byte order is little.  */       \
6189   BFD_ENDIAN_LITTLE,            /* Header byte order is little.  */     \
6190         /* object flags */                                              \
6191   (HAS_RELOC | EXEC_P | HAS_LINENO | HAS_DEBUG |                        \
6192    HAS_SYMS | HAS_LOCALS | WP_TEXT | EXTRA_O_FLAGS),                    \
6193         /* section flags */                                             \
6194   (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC | EXTRA_S_FLAGS),\
6195   UNDER,                        /* Leading symbol underscore.  */       \
6196   '/',                          /* AR_pad_char.  */                     \
6197   15,                           /* AR_max_namelen.  */                  \
6198   0,                            /* match priority.  */                  \
6199                                                                         \
6200   /* Data conversion functions.  */                                     \
6201   bfd_getl64, bfd_getl_signed_64, bfd_putl64,                           \
6202   bfd_getl32, bfd_getl_signed_32, bfd_putl32,                           \
6203   bfd_getl16, bfd_getl_signed_16, bfd_putl16,                           \
6204   /* Header conversion functions.  */                                   \
6205   bfd_getl64, bfd_getl_signed_64, bfd_putl64,                           \
6206   bfd_getl32, bfd_getl_signed_32, bfd_putl32,                           \
6207   bfd_getl16, bfd_getl_signed_16, bfd_putl16,                           \
6208         /* bfd_check_format.  */                                        \
6209   { _bfd_dummy_target, coff_object_p, bfd_generic_archive_p,            \
6210     _bfd_dummy_target },                                                \
6211        /* bfd_set_format.  */                                           \
6212   { bfd_false, coff_mkobject, _bfd_generic_mkarchive, bfd_false },      \
6213         /* bfd_write_contents.  */                                      \
6214   { bfd_false, coff_write_object_contents, _bfd_write_archive_contents, \
6215     bfd_false },                                                        \
6216                                                                         \
6217   BFD_JUMP_TABLE_GENERIC (coff),                                        \
6218   BFD_JUMP_TABLE_COPY (coff),                                           \
6219   BFD_JUMP_TABLE_CORE (_bfd_nocore),                                    \
6220   BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_coff),                           \
6221   BFD_JUMP_TABLE_SYMBOLS (coff),                                        \
6222   BFD_JUMP_TABLE_RELOCS (coff),                                         \
6223   BFD_JUMP_TABLE_WRITE (coff),                                          \
6224   BFD_JUMP_TABLE_LINK (coff),                                           \
6225   BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic),                              \
6226                                                                         \
6227   ALTERNATIVE,                                                          \
6228                                                                         \
6229   SWAP_TABLE                                                            \
6230 };