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