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