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