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