* coffcode.h (OTHER_GLOBAL_CLASS): Do not define to be C_HIDEXT
[binutils-gdb.git] / bfd / coffcode.h
1 /* Support for the generic parts of most COFF variants, for BFD.
2 Copyright 1990, 91, 92, 93, 94, 1995 Free Software Foundation, Inc.
3 Written by Cygnus Support.
4
5 This file is part of BFD, the Binary File Descriptor library.
6
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2 of the License, or
10 (at your option) any later version.
11
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with this program; if not, write to the Free Software
19 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
20
21 /*
22 Most of this hacked by Steve Chamberlain,
23 sac@cygnus.com
24 */
25 /*
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_linno_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
178 The symbol table is massaged once again, this time to create
179 the canonical table used by the BFD application. Each symbol
180 is inspected in turn, and a decision made (using the
181 @code{sclass} field) about the various flags to set in the
182 @code{asymbol}. @xref{Symbols}. The generated canonical table
183 shares strings with the hidden internal symbol table.
184
185 Any linenumbers are read from the coff file too, and attached
186 to the symbols which own the functions the linenumbers belong to.
187
188 SUBSUBSECTION
189 Symbol writing
190
191 Writing a symbol to a coff file which didn't come from a coff
192 file will lose any debugging information. The @code{asymbol}
193 structure remembers the BFD from which the symbol was taken, and on
194 output the back end makes sure that the same destination target as
195 source target is present.
196
197 When the symbols have come from a coff file then all the
198 debugging information is preserved.
199
200 Symbol tables are provided for writing to the back end in a
201 vector of pointers to pointers. This allows applications like
202 the linker to accumulate and output large symbol tables
203 without having to do too much byte copying.
204
205 This function runs through the provided symbol table and
206 patches each symbol marked as a file place holder
207 (@code{C_FILE}) to point to the next file place holder in the
208 list. It also marks each @code{offset} field in the list with
209 the offset from the first symbol of the current symbol.
210
211 Another function of this procedure is to turn the canonical
212 value form of BFD into the form used by coff. Internally, BFD
213 expects symbol values to be offsets from a section base; so a
214 symbol physically at 0x120, but in a section starting at
215 0x100, would have the value 0x20. Coff expects symbols to
216 contain their final value, so symbols have their values
217 changed at this point to reflect their sum with their owning
218 section. This transformation uses the
219 <<output_section>> field of the @code{asymbol}'s
220 @code{asection} @xref{Sections}.
221
222 o <<coff_mangle_symbols>>
223
224 This routine runs though the provided symbol table and uses
225 the offsets generated by the previous pass and the pointers
226 generated when the symbol table was read in to create the
227 structured hierachy required by coff. It changes each pointer
228 to a symbol into the index into the symbol table of the asymbol.
229
230 o <<coff_write_symbols>>
231
232 This routine runs through the symbol table and patches up the
233 symbols from their internal form into the coff way, calls the
234 bit twiddlers, and writes out the table to the file.
235
236 */
237
238 /*
239 INTERNAL_DEFINITION
240 coff_symbol_type
241
242 DESCRIPTION
243 The hidden information for an <<asymbol>> is described in a
244 <<combined_entry_type>>:
245
246 CODE_FRAGMENT
247 .
248 .typedef struct coff_ptr_struct
249 .{
250 .
251 . {* Remembers the offset from the first symbol in the file for
252 . this symbol. Generated by coff_renumber_symbols. *}
253 .unsigned int offset;
254 .
255 . {* Should the value of this symbol be renumbered. Used for
256 . XCOFF C_BSTAT symbols. Set by coff_slurp_symbol_table. *}
257 .unsigned int fix_value : 1;
258 .
259 . {* Should the tag field of this symbol be renumbered.
260 . Created by coff_pointerize_aux. *}
261 .unsigned int fix_tag : 1;
262 .
263 . {* Should the endidx field of this symbol be renumbered.
264 . Created by coff_pointerize_aux. *}
265 .unsigned int fix_end : 1;
266 .
267 . {* Should the x_csect.x_scnlen field be renumbered.
268 . Created by coff_slurp_symbol_table. *}
269 .unsigned int fix_scnlen : 1;
270 .
271 . {* The container for the symbol structure as read and translated
272 . from the file. *}
273 .
274 .union {
275 . union internal_auxent auxent;
276 . struct internal_syment syment;
277 . } u;
278 .} combined_entry_type;
279 .
280 .
281 .{* Each canonical asymbol really looks like this: *}
282 .
283 .typedef struct coff_symbol_struct
284 .{
285 . {* The actual symbol which the rest of BFD works with *}
286 .asymbol symbol;
287 .
288 . {* A pointer to the hidden information for this symbol *}
289 .combined_entry_type *native;
290 .
291 . {* A pointer to the linenumber information for this symbol *}
292 .struct lineno_cache_entry *lineno;
293 .
294 . {* Have the line numbers been relocated yet ? *}
295 .boolean done_lineno;
296 .} coff_symbol_type;
297
298
299 */
300
301 #if defined(COFF_IMAGE_WITH_PE) || (defined(COFF_OBJ_WITH_PE) && defined(PPC))
302 #include "peicode.h"
303 #else
304 #include "coffswap.h"
305 #endif
306
307 \f
308 /* void warning(); */
309
310 /*
311 * Return a word with STYP_* (scnhdr.s_flags) flags set to represent the
312 * incoming SEC_* flags. The inverse of this function is styp_to_sec_flags().
313 * NOTE: If you add to/change this routine, you should mirror the changes
314 * in styp_to_sec_flags().
315 */
316 static long
317 sec_to_styp_flags (sec_name, sec_flags)
318 CONST char *sec_name;
319 flagword sec_flags;
320 {
321 long styp_flags = 0;
322
323 if (!strcmp (sec_name, _TEXT))
324 {
325 styp_flags = STYP_TEXT;
326 }
327 else if (!strcmp (sec_name, _DATA))
328 {
329 styp_flags = STYP_DATA;
330 }
331 else if (!strcmp (sec_name, _BSS))
332 {
333 styp_flags = STYP_BSS;
334 #ifdef _COMMENT
335 }
336 else if (!strcmp (sec_name, _COMMENT))
337 {
338 styp_flags = STYP_INFO;
339 #endif /* _COMMENT */
340 #ifdef _LIB
341 }
342 else if (!strcmp (sec_name, _LIB))
343 {
344 styp_flags = STYP_LIB;
345 #endif /* _LIB */
346 #ifdef _LIT
347 }
348 else if (!strcmp (sec_name, _LIT))
349 {
350 styp_flags = STYP_LIT;
351 #endif /* _LIT */
352 }
353 else if (!strcmp (sec_name, ".debug"))
354 {
355 #ifdef STYP_DEBUG
356 styp_flags = STYP_DEBUG;
357 #else
358 styp_flags = STYP_INFO;
359 #endif
360 }
361 else if (!strncmp (sec_name, ".stab", 5))
362 {
363 styp_flags = STYP_INFO;
364 }
365 #ifdef COFF_WITH_PE
366 else if (!strcmp (sec_name, ".edata"))
367 {
368 styp_flags = STYP_DATA;
369 }
370 #endif
371 /* Try and figure out what it should be */
372 else if (sec_flags & SEC_CODE)
373 {
374 styp_flags = STYP_TEXT;
375 }
376 else if (sec_flags & SEC_DATA)
377 {
378 styp_flags = STYP_DATA;
379 }
380 else if (sec_flags & SEC_READONLY)
381 {
382 #ifdef STYP_LIT /* 29k readonly text/data section */
383 styp_flags = STYP_LIT;
384 #else
385 styp_flags = STYP_TEXT;
386 #endif /* STYP_LIT */
387 }
388 else if (sec_flags & SEC_LOAD)
389 {
390 styp_flags = STYP_TEXT;
391 }
392 else if (sec_flags & SEC_ALLOC)
393 {
394 styp_flags = STYP_BSS;
395 }
396
397 #ifdef STYP_NOLOAD
398 if ((sec_flags & (SEC_NEVER_LOAD | SEC_COFF_SHARED_LIBRARY)) != 0)
399 styp_flags |= STYP_NOLOAD;
400 #endif
401
402 return (styp_flags);
403 }
404 /*
405 * Return a word with SEC_* flags set to represent the incoming
406 * STYP_* flags (from scnhdr.s_flags). The inverse of this
407 * function is sec_to_styp_flags().
408 * NOTE: If you add to/change this routine, you should mirror the changes
409 * in sec_to_styp_flags().
410 */
411 static flagword
412 styp_to_sec_flags (abfd, hdr, name)
413 bfd *abfd;
414 PTR hdr;
415 const char *name;
416 {
417 struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
418 long styp_flags = internal_s->s_flags;
419 flagword sec_flags = 0;
420
421 #ifdef STYP_NOLOAD
422 if (styp_flags & STYP_NOLOAD)
423 {
424 sec_flags |= SEC_NEVER_LOAD;
425 }
426 #endif /* STYP_NOLOAD */
427
428 /* For 386 COFF, at least, an unloadable text or data section is
429 actually a shared library section. */
430 if (styp_flags & STYP_TEXT)
431 {
432 if (sec_flags & SEC_NEVER_LOAD)
433 sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
434 else
435 sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
436 }
437 else if (styp_flags & STYP_DATA)
438 {
439 if (sec_flags & SEC_NEVER_LOAD)
440 sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
441 else
442 sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
443 }
444 else if (styp_flags & STYP_BSS)
445 {
446 #ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
447 if (sec_flags & SEC_NEVER_LOAD)
448 sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
449 else
450 #endif
451 sec_flags |= SEC_ALLOC;
452 }
453 else if (styp_flags & STYP_INFO)
454 {
455 /* We mark these as SEC_DEBUGGING, but only if COFF_PAGE_SIZE is
456 defined. coff_compute_section_file_positions uses
457 COFF_PAGE_SIZE to ensure that the low order bits of the
458 section VMA and the file offset match. If we don't know
459 COFF_PAGE_SIZE, we can't ensure the correct correspondence,
460 and demand page loading of the file will fail. */
461 #ifdef COFF_PAGE_SIZE
462 sec_flags |= SEC_DEBUGGING;
463 #endif
464 }
465 else if (strcmp (name, _TEXT) == 0)
466 {
467 if (sec_flags & SEC_NEVER_LOAD)
468 sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
469 else
470 sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
471 }
472 else if (strcmp (name, _DATA) == 0)
473 {
474 if (sec_flags & SEC_NEVER_LOAD)
475 sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
476 else
477 sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
478 }
479 else if (strcmp (name, _BSS) == 0)
480 {
481 #ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
482 if (sec_flags & SEC_NEVER_LOAD)
483 sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
484 else
485 #endif
486 sec_flags |= SEC_ALLOC;
487 }
488 else if (strcmp (name, ".debug") == 0
489 #ifdef _COMMENT
490 || strcmp (name, _COMMENT) == 0
491 #endif
492 || strncmp (name, ".stab", 5) == 0)
493 {
494 #ifdef COFF_PAGE_SIZE
495 sec_flags |= SEC_DEBUGGING;
496 #endif
497 }
498 #ifdef _LIB
499 else if (strcmp (name, _LIB) == 0)
500 ;
501 #endif
502 #ifdef _LIT
503 else if (strcmp (name, _LIT) == 0)
504 {
505 sec_flags = SEC_LOAD | SEC_ALLOC | SEC_READONLY;
506 }
507 #endif
508 else
509 {
510 sec_flags |= SEC_ALLOC | SEC_LOAD;
511 }
512
513 #ifdef STYP_LIT /* A29k readonly text/data section type */
514 if ((styp_flags & STYP_LIT) == STYP_LIT)
515 {
516 sec_flags = (SEC_LOAD | SEC_ALLOC | SEC_READONLY);
517 }
518 #endif /* STYP_LIT */
519 #ifdef STYP_OTHER_LOAD /* Other loaded sections */
520 if (styp_flags & STYP_OTHER_LOAD)
521 {
522 sec_flags = (SEC_LOAD | SEC_ALLOC);
523 }
524 #endif /* STYP_SDATA */
525
526 return (sec_flags);
527 }
528
529 #define get_index(symbol) ((symbol)->udata.i)
530
531 /*
532 INTERNAL_DEFINITION
533 bfd_coff_backend_data
534
535 CODE_FRAGMENT
536
537 Special entry points for gdb to swap in coff symbol table parts:
538 .typedef struct
539 .{
540 . void (*_bfd_coff_swap_aux_in) PARAMS ((
541 . bfd *abfd,
542 . PTR ext,
543 . int type,
544 . int class,
545 . int indaux,
546 . int numaux,
547 . PTR in));
548 .
549 . void (*_bfd_coff_swap_sym_in) PARAMS ((
550 . bfd *abfd ,
551 . PTR ext,
552 . PTR in));
553 .
554 . void (*_bfd_coff_swap_lineno_in) PARAMS ((
555 . bfd *abfd,
556 . PTR ext,
557 . PTR in));
558 .
559
560 Special entry points for gas to swap out coff parts:
561
562 . unsigned int (*_bfd_coff_swap_aux_out) PARAMS ((
563 . bfd *abfd,
564 . PTR in,
565 . int type,
566 . int class,
567 . int indaux,
568 . int numaux,
569 . PTR ext));
570 .
571 . unsigned int (*_bfd_coff_swap_sym_out) PARAMS ((
572 . bfd *abfd,
573 . PTR in,
574 . PTR ext));
575 .
576 . unsigned int (*_bfd_coff_swap_lineno_out) PARAMS ((
577 . bfd *abfd,
578 . PTR in,
579 . PTR ext));
580 .
581 . unsigned int (*_bfd_coff_swap_reloc_out) PARAMS ((
582 . bfd *abfd,
583 . PTR src,
584 . PTR dst));
585 .
586 . unsigned int (*_bfd_coff_swap_filehdr_out) PARAMS ((
587 . bfd *abfd,
588 . PTR in,
589 . PTR out));
590 .
591 . unsigned int (*_bfd_coff_swap_aouthdr_out) PARAMS ((
592 . bfd *abfd,
593 . PTR in,
594 . PTR out));
595 .
596 . unsigned int (*_bfd_coff_swap_scnhdr_out) PARAMS ((
597 . bfd *abfd,
598 . PTR in,
599 . PTR out));
600 .
601
602 Special entry points for generic COFF routines to call target
603 dependent COFF routines:
604
605 . unsigned int _bfd_filhsz;
606 . unsigned int _bfd_aoutsz;
607 . unsigned int _bfd_scnhsz;
608 . unsigned int _bfd_symesz;
609 . unsigned int _bfd_auxesz;
610 . unsigned int _bfd_relsz;
611 . unsigned int _bfd_linesz;
612 . boolean _bfd_coff_long_filenames;
613 . void (*_bfd_coff_swap_filehdr_in) PARAMS ((
614 . bfd *abfd,
615 . PTR ext,
616 . PTR in));
617 . void (*_bfd_coff_swap_aouthdr_in) PARAMS ((
618 . bfd *abfd,
619 . PTR ext,
620 . PTR in));
621 . void (*_bfd_coff_swap_scnhdr_in) PARAMS ((
622 . bfd *abfd,
623 . PTR ext,
624 . PTR in));
625 . void (*_bfd_coff_swap_reloc_in) PARAMS ((
626 . bfd *abfd,
627 . PTR ext,
628 . PTR in));
629 . boolean (*_bfd_coff_bad_format_hook) PARAMS ((
630 . bfd *abfd,
631 . PTR internal_filehdr));
632 . boolean (*_bfd_coff_set_arch_mach_hook) PARAMS ((
633 . bfd *abfd,
634 . PTR internal_filehdr));
635 . PTR (*_bfd_coff_mkobject_hook) PARAMS ((
636 . bfd *abfd,
637 . PTR internal_filehdr,
638 . PTR internal_aouthdr));
639 . flagword (*_bfd_styp_to_sec_flags_hook) PARAMS ((
640 . bfd *abfd,
641 . PTR internal_scnhdr,
642 . const char *name));
643 . void (*_bfd_set_alignment_hook) PARAMS ((
644 . bfd *abfd,
645 . asection *sec,
646 . PTR internal_scnhdr));
647 . boolean (*_bfd_coff_slurp_symbol_table) PARAMS ((
648 . bfd *abfd));
649 . boolean (*_bfd_coff_symname_in_debug) PARAMS ((
650 . bfd *abfd,
651 . struct internal_syment *sym));
652 . void (*_bfd_coff_reloc16_extra_cases) PARAMS ((
653 . bfd *abfd,
654 . struct bfd_link_info *link_info,
655 . struct bfd_link_order *link_order,
656 . arelent *reloc,
657 . bfd_byte *data,
658 . unsigned int *src_ptr,
659 . unsigned int *dst_ptr));
660 . int (*_bfd_coff_reloc16_estimate) PARAMS ((
661 . bfd *abfd,
662 . asection *input_section,
663 . arelent *r,
664 . unsigned int shrink,
665 . struct bfd_link_info *link_info));
666 . boolean (*_bfd_coff_sym_is_global) PARAMS ((
667 . bfd *abfd,
668 . struct internal_syment *));
669 . void (*_bfd_coff_compute_section_file_positions) PARAMS ((
670 . bfd *abfd));
671 . boolean (*_bfd_coff_start_final_link) PARAMS ((
672 . bfd *output_bfd,
673 . struct bfd_link_info *info));
674 . boolean (*_bfd_coff_relocate_section) PARAMS ((
675 . bfd *output_bfd,
676 . struct bfd_link_info *info,
677 . bfd *input_bfd,
678 . asection *input_section,
679 . bfd_byte *contents,
680 . struct internal_reloc *relocs,
681 . struct internal_syment *syms,
682 . asection **sections));
683 . reloc_howto_type *(*_bfd_coff_rtype_to_howto) PARAMS ((
684 . bfd *abfd,
685 . asection *sec,
686 . struct internal_reloc *rel,
687 . struct coff_link_hash_entry *h,
688 . struct internal_syment *sym,
689 . bfd_vma *addendp));
690 . boolean (*_bfd_coff_adjust_symndx) PARAMS ((
691 . bfd *obfd,
692 . struct bfd_link_info *info,
693 . bfd *ibfd,
694 . asection *sec,
695 . struct internal_reloc *reloc,
696 . boolean *adjustedp));
697 .
698 .} bfd_coff_backend_data;
699 .
700 .#define coff_backend_info(abfd) ((bfd_coff_backend_data *) (abfd)->xvec->backend_data)
701 .
702 .#define bfd_coff_swap_aux_in(a,e,t,c,ind,num,i) \
703 . ((coff_backend_info (a)->_bfd_coff_swap_aux_in) (a,e,t,c,ind,num,i))
704 .
705 .#define bfd_coff_swap_sym_in(a,e,i) \
706 . ((coff_backend_info (a)->_bfd_coff_swap_sym_in) (a,e,i))
707 .
708 .#define bfd_coff_swap_lineno_in(a,e,i) \
709 . ((coff_backend_info ( a)->_bfd_coff_swap_lineno_in) (a,e,i))
710 .
711 .#define bfd_coff_swap_reloc_out(abfd, i, o) \
712 . ((coff_backend_info (abfd)->_bfd_coff_swap_reloc_out) (abfd, i, o))
713 .
714 .#define bfd_coff_swap_lineno_out(abfd, i, o) \
715 . ((coff_backend_info (abfd)->_bfd_coff_swap_lineno_out) (abfd, i, o))
716 .
717 .#define bfd_coff_swap_aux_out(a,i,t,c,ind,num,o) \
718 . ((coff_backend_info (a)->_bfd_coff_swap_aux_out) (a,i,t,c,ind,num,o))
719 .
720 .#define bfd_coff_swap_sym_out(abfd, i,o) \
721 . ((coff_backend_info (abfd)->_bfd_coff_swap_sym_out) (abfd, i, o))
722 .
723 .#define bfd_coff_swap_scnhdr_out(abfd, i,o) \
724 . ((coff_backend_info (abfd)->_bfd_coff_swap_scnhdr_out) (abfd, i, o))
725 .
726 .#define bfd_coff_swap_filehdr_out(abfd, i,o) \
727 . ((coff_backend_info (abfd)->_bfd_coff_swap_filehdr_out) (abfd, i, o))
728 .
729 .#define bfd_coff_swap_aouthdr_out(abfd, i,o) \
730 . ((coff_backend_info (abfd)->_bfd_coff_swap_aouthdr_out) (abfd, i, o))
731 .
732 .#define bfd_coff_filhsz(abfd) (coff_backend_info (abfd)->_bfd_filhsz)
733 .#define bfd_coff_aoutsz(abfd) (coff_backend_info (abfd)->_bfd_aoutsz)
734 .#define bfd_coff_scnhsz(abfd) (coff_backend_info (abfd)->_bfd_scnhsz)
735 .#define bfd_coff_symesz(abfd) (coff_backend_info (abfd)->_bfd_symesz)
736 .#define bfd_coff_auxesz(abfd) (coff_backend_info (abfd)->_bfd_auxesz)
737 .#define bfd_coff_relsz(abfd) (coff_backend_info (abfd)->_bfd_relsz)
738 .#define bfd_coff_linesz(abfd) (coff_backend_info (abfd)->_bfd_linesz)
739 .#define bfd_coff_long_filenames(abfd) (coff_backend_info (abfd)->_bfd_coff_long_filenames)
740 .#define bfd_coff_swap_filehdr_in(abfd, i,o) \
741 . ((coff_backend_info (abfd)->_bfd_coff_swap_filehdr_in) (abfd, i, o))
742 .
743 .#define bfd_coff_swap_aouthdr_in(abfd, i,o) \
744 . ((coff_backend_info (abfd)->_bfd_coff_swap_aouthdr_in) (abfd, i, o))
745 .
746 .#define bfd_coff_swap_scnhdr_in(abfd, i,o) \
747 . ((coff_backend_info (abfd)->_bfd_coff_swap_scnhdr_in) (abfd, i, o))
748 .
749 .#define bfd_coff_swap_reloc_in(abfd, i, o) \
750 . ((coff_backend_info (abfd)->_bfd_coff_swap_reloc_in) (abfd, i, o))
751 .
752 .#define bfd_coff_bad_format_hook(abfd, filehdr) \
753 . ((coff_backend_info (abfd)->_bfd_coff_bad_format_hook) (abfd, filehdr))
754 .
755 .#define bfd_coff_set_arch_mach_hook(abfd, filehdr)\
756 . ((coff_backend_info (abfd)->_bfd_coff_set_arch_mach_hook) (abfd, filehdr))
757 .#define bfd_coff_mkobject_hook(abfd, filehdr, aouthdr)\
758 . ((coff_backend_info (abfd)->_bfd_coff_mkobject_hook) (abfd, filehdr, aouthdr))
759 .
760 .#define bfd_coff_styp_to_sec_flags_hook(abfd, scnhdr, name)\
761 . ((coff_backend_info (abfd)->_bfd_styp_to_sec_flags_hook) (abfd, scnhdr, name))
762 .
763 .#define bfd_coff_set_alignment_hook(abfd, sec, scnhdr)\
764 . ((coff_backend_info (abfd)->_bfd_set_alignment_hook) (abfd, sec, scnhdr))
765 .
766 .#define bfd_coff_slurp_symbol_table(abfd)\
767 . ((coff_backend_info (abfd)->_bfd_coff_slurp_symbol_table) (abfd))
768 .
769 .#define bfd_coff_symname_in_debug(abfd, sym)\
770 . ((coff_backend_info (abfd)->_bfd_coff_symname_in_debug) (abfd, sym))
771 .
772 .#define bfd_coff_reloc16_extra_cases(abfd, link_info, link_order, reloc, data, src_ptr, dst_ptr)\
773 . ((coff_backend_info (abfd)->_bfd_coff_reloc16_extra_cases)\
774 . (abfd, link_info, link_order, reloc, data, src_ptr, dst_ptr))
775 .
776 .#define bfd_coff_reloc16_estimate(abfd, section, reloc, shrink, link_info)\
777 . ((coff_backend_info (abfd)->_bfd_coff_reloc16_estimate)\
778 . (abfd, section, reloc, shrink, link_info))
779 .
780 .#define bfd_coff_sym_is_global(abfd, sym)\
781 . ((coff_backend_info (abfd)->_bfd_coff_sym_is_global)\
782 . (abfd, sym))
783 .
784 .#define bfd_coff_compute_section_file_positions(abfd)\
785 . ((coff_backend_info (abfd)->_bfd_coff_compute_section_file_positions)\
786 . (abfd))
787 .
788 .#define bfd_coff_start_final_link(obfd, info)\
789 . ((coff_backend_info (obfd)->_bfd_coff_start_final_link)\
790 . (obfd, info))
791 .#define bfd_coff_relocate_section(obfd,info,ibfd,o,con,rel,isyms,secs)\
792 . ((coff_backend_info (ibfd)->_bfd_coff_relocate_section)\
793 . (obfd, info, ibfd, o, con, rel, isyms, secs))
794 .#define bfd_coff_rtype_to_howto(abfd, sec, rel, h, sym, addendp)\
795 . ((coff_backend_info (abfd)->_bfd_coff_rtype_to_howto)\
796 . (abfd, sec, rel, h, sym, addendp))
797 .#define bfd_coff_adjust_symndx(obfd, info, ibfd, sec, rel, adjustedp)\
798 . ((coff_backend_info (abfd)->_bfd_coff_adjust_symndx)\
799 . (obfd, info, ibfd, sec, rel, adjustedp))
800 .
801 */
802
803 /* See whether the magic number matches. */
804
805 static boolean
806 coff_bad_format_hook (abfd, filehdr)
807 bfd * abfd;
808 PTR filehdr;
809 {
810 struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
811
812 if (BADMAG (*internal_f))
813 return false;
814
815 /* if the optional header is NULL or not the correct size then
816 quit; the only difference I can see between m88k dgux headers (MC88DMAGIC)
817 and Intel 960 readwrite headers (I960WRMAGIC) is that the
818 optional header is of a different size.
819
820 But the mips keeps extra stuff in it's opthdr, so dont check
821 when doing that
822 */
823
824 #if defined(M88) || defined(I960)
825 if (internal_f->f_opthdr != 0 && AOUTSZ != internal_f->f_opthdr)
826 return false;
827 #endif
828
829 return true;
830 }
831
832 /*
833 initialize a section structure with information peculiar to this
834 particular implementation of coff
835 */
836
837 static boolean
838 coff_new_section_hook (abfd, section)
839 bfd * abfd;
840 asection * section;
841 {
842 section->alignment_power = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
843
844 /* Allocate aux records for section symbols, to store size and
845 related info.
846
847 @@ Shouldn't use constant multiplier here! */
848 coffsymbol (section->symbol)->native =
849 (combined_entry_type *) bfd_zalloc (abfd,
850 sizeof (combined_entry_type) * 10);
851
852 /* The .stab section must be aligned to 2**2 at most, because
853 otherwise there may be gaps in the section which gdb will not
854 know how to interpret. Examining the section name is a hack, but
855 that is also how gdb locates the section.
856 We need to handle the .ctors and .dtors sections similarly, to
857 avoid introducing null words in the tables. */
858 if (COFF_DEFAULT_SECTION_ALIGNMENT_POWER > 2
859 && (strncmp (section->name, ".stab", 5) == 0
860 || strcmp (section->name, ".ctors") == 0
861 || strcmp (section->name, ".dtors") == 0))
862 section->alignment_power = 2;
863
864 return true;
865 }
866
867 #ifdef I960
868
869 /* Set the alignment of a BFD section. */
870
871 static void
872 coff_set_alignment_hook (abfd, section, scnhdr)
873 bfd * abfd;
874 asection * section;
875 PTR scnhdr;
876 {
877 struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
878 unsigned int i;
879
880 for (i = 0; i < 32; i++)
881 if ((1 << i) >= hdr->s_align)
882 break;
883 section->alignment_power = i;
884 }
885
886 #else /* ! I960 */
887
888 #define coff_set_alignment_hook \
889 ((void (*) PARAMS ((bfd *, asection *, PTR))) bfd_void)
890
891 #endif /* ! I960 */
892
893 #ifndef coff_mkobject
894 static boolean
895 coff_mkobject (abfd)
896 bfd * abfd;
897 {
898 coff_data_type *coff;
899
900 abfd->tdata.coff_obj_data = (struct coff_tdata *) bfd_zalloc (abfd, sizeof (coff_data_type));
901 if (abfd->tdata.coff_obj_data == 0)
902 {
903 bfd_set_error (bfd_error_no_memory);
904 return false;
905 }
906 coff = coff_data (abfd);
907 coff->symbols = (coff_symbol_type *) NULL;
908 coff->conversion_table = (unsigned int *) NULL;
909 coff->raw_syments = (struct coff_ptr_struct *) NULL;
910 coff->relocbase = 0;
911 /* make_abs_section(abfd);*/
912
913 return true;
914 }
915 #endif
916
917 /* Create the COFF backend specific information. */
918 #ifndef coff_mkobject_hook
919 static PTR
920 coff_mkobject_hook (abfd, filehdr, aouthdr)
921 bfd * abfd;
922 PTR filehdr;
923 PTR aouthdr;
924 {
925 struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
926 coff_data_type *coff;
927
928 if (coff_mkobject (abfd) == false)
929 return NULL;
930
931 coff = coff_data (abfd);
932
933 coff->sym_filepos = internal_f->f_symptr;
934
935 /* These members communicate important constants about the symbol
936 table to GDB's symbol-reading code. These `constants'
937 unfortunately vary among coff implementations... */
938 coff->local_n_btmask = N_BTMASK;
939 coff->local_n_btshft = N_BTSHFT;
940 coff->local_n_tmask = N_TMASK;
941 coff->local_n_tshift = N_TSHIFT;
942 coff->local_symesz = SYMESZ;
943 coff->local_auxesz = AUXESZ;
944 coff->local_linesz = LINESZ;
945
946 obj_raw_syment_count (abfd) =
947 obj_conv_table_size (abfd) =
948 internal_f->f_nsyms;
949
950 return (PTR) coff;
951 }
952 #endif
953
954 /* Determine the machine architecture and type. FIXME: This is target
955 dependent because the magic numbers are defined in the target
956 dependent header files. But there is no particular need for this.
957 If the magic numbers were moved to a separate file, this function
958 would be target independent and would also be much more successful
959 at linking together COFF files for different architectures. */
960
961 static boolean
962 coff_set_arch_mach_hook (abfd, filehdr)
963 bfd *abfd;
964 PTR filehdr;
965 {
966 long machine;
967 enum bfd_architecture arch;
968 struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
969
970 machine = 0;
971 switch (internal_f->f_magic)
972 {
973 #ifdef PPCMAGIC
974 case PPCMAGIC:
975 arch = bfd_arch_powerpc;
976 machine = 0; /* what does this mean? (krk) */
977 break;
978 #endif
979 #ifdef I386MAGIC
980 case I386MAGIC:
981 case I386PTXMAGIC:
982 case I386AIXMAGIC: /* Danbury PS/2 AIX C Compiler */
983 case LYNXCOFFMAGIC: /* shadows the m68k Lynx number below, sigh */
984 arch = bfd_arch_i386;
985 machine = 0;
986 break;
987 #endif
988 #ifdef A29K_MAGIC_BIG
989 case A29K_MAGIC_BIG:
990 case A29K_MAGIC_LITTLE:
991 arch = bfd_arch_a29k;
992 machine = 0;
993 break;
994 #endif
995 #ifdef ARMMAGIC
996 case ARMMAGIC:
997 arch = bfd_arch_arm;
998 machine =0;
999 break;
1000 #endif
1001 #ifdef MC68MAGIC
1002 case MC68MAGIC:
1003 case M68MAGIC:
1004 #ifdef MC68KBCSMAGIC
1005 case MC68KBCSMAGIC:
1006 #endif
1007 #ifdef APOLLOM68KMAGIC
1008 case APOLLOM68KMAGIC:
1009 #endif
1010 #ifdef LYNXCOFFMAGIC
1011 case LYNXCOFFMAGIC:
1012 #endif
1013 arch = bfd_arch_m68k;
1014 machine = 68020;
1015 break;
1016 #endif
1017 #ifdef MC88MAGIC
1018 case MC88MAGIC:
1019 case MC88DMAGIC:
1020 case MC88OMAGIC:
1021 arch = bfd_arch_m88k;
1022 machine = 88100;
1023 break;
1024 #endif
1025 #ifdef Z8KMAGIC
1026 case Z8KMAGIC:
1027 arch = bfd_arch_z8k;
1028 switch (internal_f->f_flags & F_MACHMASK)
1029 {
1030 case F_Z8001:
1031 machine = bfd_mach_z8001;
1032 break;
1033 case F_Z8002:
1034 machine = bfd_mach_z8002;
1035 break;
1036 default:
1037 return false;
1038 }
1039 break;
1040 #endif
1041 #ifdef I960
1042 #ifdef I960ROMAGIC
1043 case I960ROMAGIC:
1044 case I960RWMAGIC:
1045 arch = bfd_arch_i960;
1046 switch (F_I960TYPE & internal_f->f_flags)
1047 {
1048 default:
1049 case F_I960CORE:
1050 machine = bfd_mach_i960_core;
1051 break;
1052 case F_I960KB:
1053 machine = bfd_mach_i960_kb_sb;
1054 break;
1055 case F_I960MC:
1056 machine = bfd_mach_i960_mc;
1057 break;
1058 case F_I960XA:
1059 machine = bfd_mach_i960_xa;
1060 break;
1061 case F_I960CA:
1062 machine = bfd_mach_i960_ca;
1063 break;
1064 case F_I960KA:
1065 machine = bfd_mach_i960_ka_sa;
1066 break;
1067 /* start-sanitize-i960xl */
1068 case F_I960XL:
1069 machine = bfd_mach_i960_xl;
1070 break;
1071 /* end-sanitize-i960xl */
1072 }
1073 break;
1074 #endif
1075 #endif
1076
1077 #ifdef U802ROMAGIC
1078 case U802ROMAGIC:
1079 case U802WRMAGIC:
1080 case U802TOCMAGIC:
1081 #ifdef POWERMAC
1082 /* PowerPC Macs use the same magic numbers as RS/6000 (because
1083 that's how they were bootstrapped originally), but they are
1084 always PowerPC architecture. */
1085 arch = bfd_arch_powerpc;
1086 machine = 601;
1087 #else
1088 /* FIXME The architecture and machine can now (as of AIX 4.1) be
1089 identified by looking at fields in the a.out header. */
1090 arch = bfd_arch_rs6000;
1091 machine = 6000;
1092 #endif /* POWERMAC */
1093 break;
1094 #endif
1095
1096 #ifdef WE32KMAGIC
1097 case WE32KMAGIC:
1098 arch = bfd_arch_we32k;
1099 machine = 0;
1100 break;
1101 #endif
1102
1103 #ifdef H8300MAGIC
1104 case H8300MAGIC:
1105 arch = bfd_arch_h8300;
1106 machine = bfd_mach_h8300;
1107 /* !! FIXME this probably isn't the right place for this */
1108 abfd->flags |= BFD_IS_RELAXABLE;
1109 break;
1110 #endif
1111
1112 #ifdef H8300HMAGIC
1113 case H8300HMAGIC:
1114 arch = bfd_arch_h8300;
1115 machine = bfd_mach_h8300h;
1116 /* !! FIXME this probably isn't the right place for this */
1117 abfd->flags |= BFD_IS_RELAXABLE;
1118 break;
1119 #endif
1120
1121 #ifdef SH_ARCH_MAGIC_BIG
1122 case SH_ARCH_MAGIC_BIG:
1123 case SH_ARCH_MAGIC_LITTLE:
1124 arch = bfd_arch_sh;
1125 machine = 0;
1126 break;
1127 #endif
1128
1129 #ifdef H8500MAGIC
1130 case H8500MAGIC:
1131 arch = bfd_arch_h8500;
1132 machine = 0;
1133 break;
1134 #endif
1135
1136 #ifdef SPARCMAGIC
1137 case SPARCMAGIC:
1138 #ifdef LYNXCOFFMAGIC
1139 case LYNXCOFFMAGIC:
1140 #endif
1141 arch = bfd_arch_sparc;
1142 machine = 0;
1143 break;
1144 #endif
1145
1146 default: /* Unreadable input file type */
1147 arch = bfd_arch_obscure;
1148 break;
1149 }
1150
1151 bfd_default_set_arch_mach (abfd, arch, machine);
1152 return true;
1153 }
1154
1155 #ifdef SYMNAME_IN_DEBUG
1156
1157 static boolean
1158 symname_in_debug_hook (abfd, sym)
1159 bfd * abfd;
1160 struct internal_syment *sym;
1161 {
1162 return SYMNAME_IN_DEBUG (sym) ? true : false;
1163 }
1164
1165 #else
1166
1167 #define symname_in_debug_hook \
1168 (boolean (*) PARAMS ((bfd *, struct internal_syment *))) bfd_false
1169
1170 #endif
1171
1172 /*
1173 SUBSUBSECTION
1174 Writing relocations
1175
1176 To write relocations, the back end steps though the
1177 canonical relocation table and create an
1178 @code{internal_reloc}. The symbol index to use is removed from
1179 the @code{offset} field in the symbol table supplied. The
1180 address comes directly from the sum of the section base
1181 address and the relocation offset; the type is dug directly
1182 from the howto field. Then the @code{internal_reloc} is
1183 swapped into the shape of an @code{external_reloc} and written
1184 out to disk.
1185
1186 */
1187
1188 static boolean
1189 coff_write_relocs (abfd, first_undef)
1190 bfd * abfd;
1191 int first_undef;
1192 {
1193 asection *s;
1194 for (s = abfd->sections; s != (asection *) NULL; s = s->next)
1195 {
1196 unsigned int i;
1197 struct external_reloc dst;
1198
1199 arelent **p = s->orelocation;
1200 if (bfd_seek (abfd, s->rel_filepos, SEEK_SET) != 0)
1201 return false;
1202 for (i = 0; i < s->reloc_count; i++)
1203 {
1204 struct internal_reloc n;
1205 arelent *q = p[i];
1206 memset ((PTR) & n, 0, sizeof (n));
1207
1208 /* Now we've renumbered the symbols we know where the
1209 undefined symbols live in the table. Check the reloc
1210 entries for symbols who's output bfd isn't the right one.
1211 This is because the symbol was undefined (which means
1212 that all the pointers are never made to point to the same
1213 place). This is a bad thing,'cause the symbols attached
1214 to the output bfd are indexed, so that the relocation
1215 entries know which symbol index they point to. So we
1216 have to look up the output symbol here. */
1217
1218 if (q->sym_ptr_ptr[0]->the_bfd != abfd)
1219 {
1220 int i;
1221 const char *sname = q->sym_ptr_ptr[0]->name;
1222 asymbol **outsyms = abfd->outsymbols;
1223 for (i = first_undef; outsyms[i]; i++)
1224 {
1225 const char *intable = outsyms[i]->name;
1226 if (strcmp (intable, sname) == 0) {
1227 /* got a hit, so repoint the reloc */
1228 q->sym_ptr_ptr = outsyms + i;
1229 break;
1230 }
1231 }
1232 }
1233
1234 n.r_vaddr = q->address + s->vma;
1235
1236 #ifdef R_IHCONST
1237 /* The 29k const/consth reloc pair is a real kludge. The consth
1238 part doesn't have a symbol; it has an offset. So rebuilt
1239 that here. */
1240 if (q->howto->type == R_IHCONST)
1241 n.r_symndx = q->addend;
1242 else
1243 #endif
1244 if (q->sym_ptr_ptr)
1245 {
1246 if (q->sym_ptr_ptr == bfd_abs_section_ptr->symbol_ptr_ptr)
1247 /* This is a relocation relative to the absolute symbol. */
1248 n.r_symndx = -1;
1249 else
1250 {
1251 n.r_symndx = get_index ((*(q->sym_ptr_ptr)));
1252 /* Take notice if the symbol reloc points to a symbol
1253 we don't have in our symbol table. What should we
1254 do for this?? */
1255 if (n.r_symndx > obj_conv_table_size (abfd))
1256 abort ();
1257 }
1258 }
1259
1260 #ifdef SWAP_OUT_RELOC_OFFSET
1261 n.r_offset = q->addend;
1262 #endif
1263
1264 #ifdef SELECT_RELOC
1265 /* Work out reloc type from what is required */
1266 SELECT_RELOC (n, q->howto);
1267 #else
1268 n.r_type = q->howto->type;
1269 #endif
1270 coff_swap_reloc_out (abfd, &n, &dst);
1271 if (bfd_write ((PTR) & dst, 1, RELSZ, abfd) != RELSZ)
1272 return false;
1273 }
1274 }
1275
1276 return true;
1277 }
1278
1279 /* Set flags and magic number of a coff file from architecture and machine
1280 type. Result is true if we can represent the arch&type, false if not. */
1281
1282 static boolean
1283 coff_set_flags (abfd, magicp, flagsp)
1284 bfd * abfd;
1285 unsigned *magicp;
1286 unsigned short *flagsp;
1287 {
1288 switch (bfd_get_arch (abfd))
1289 {
1290 #ifdef Z8KMAGIC
1291 case bfd_arch_z8k:
1292 *magicp = Z8KMAGIC;
1293 switch (bfd_get_mach (abfd))
1294 {
1295 case bfd_mach_z8001:
1296 *flagsp = F_Z8001;
1297 break;
1298 case bfd_mach_z8002:
1299 *flagsp = F_Z8002;
1300 break;
1301 default:
1302 return false;
1303 }
1304 return true;
1305 #endif
1306 #ifdef I960ROMAGIC
1307
1308 case bfd_arch_i960:
1309
1310 {
1311 unsigned flags;
1312 *magicp = I960ROMAGIC;
1313 /*
1314 ((bfd_get_file_flags(abfd) & WP_TEXT) ? I960ROMAGIC :
1315 I960RWMAGIC); FIXME???
1316 */
1317 switch (bfd_get_mach (abfd))
1318 {
1319 case bfd_mach_i960_core:
1320 flags = F_I960CORE;
1321 break;
1322 case bfd_mach_i960_kb_sb:
1323 flags = F_I960KB;
1324 break;
1325 case bfd_mach_i960_mc:
1326 flags = F_I960MC;
1327 break;
1328 case bfd_mach_i960_xa:
1329 flags = F_I960XA;
1330 break;
1331 case bfd_mach_i960_ca:
1332 flags = F_I960CA;
1333 break;
1334 case bfd_mach_i960_ka_sa:
1335 flags = F_I960KA;
1336 break;
1337 /* start-sanitize-i960xl */
1338 case bfd_mach_i960_xl:
1339 flags = F_I960XL;
1340 break;
1341 /* end-sanitize-i960xl */
1342 default:
1343 return false;
1344 }
1345 *flagsp = flags;
1346 return true;
1347 }
1348 break;
1349 #endif
1350 #ifdef ARMMAGIC
1351 case bfd_arch_arm:
1352 *magicp = ARMMAGIC;
1353 return true;
1354 #endif
1355 #ifdef PPCMAGIC
1356 case bfd_arch_powerpc:
1357 *magicp = PPCMAGIC;
1358 return true;
1359 break;
1360 #endif
1361 #ifdef I386MAGIC
1362 case bfd_arch_i386:
1363 *magicp = I386MAGIC;
1364 #ifdef LYNXOS
1365 /* Just overwrite the usual value if we're doing Lynx. */
1366 *magicp = LYNXCOFFMAGIC;
1367 #endif
1368 return true;
1369 break;
1370 #endif
1371 #ifdef MC68MAGIC
1372 case bfd_arch_m68k:
1373 #ifdef APOLLOM68KMAGIC
1374 *magicp = APOLLO_COFF_VERSION_NUMBER;
1375 #else
1376 *magicp = MC68MAGIC;
1377 #endif
1378 #ifdef LYNXOS
1379 /* Just overwrite the usual value if we're doing Lynx. */
1380 *magicp = LYNXCOFFMAGIC;
1381 #endif
1382 return true;
1383 break;
1384 #endif
1385
1386 #ifdef MC88MAGIC
1387 case bfd_arch_m88k:
1388 *magicp = MC88OMAGIC;
1389 return true;
1390 break;
1391 #endif
1392 #ifdef H8300MAGIC
1393 case bfd_arch_h8300:
1394 switch (bfd_get_mach (abfd))
1395 {
1396 case bfd_mach_h8300:
1397 *magicp = H8300MAGIC;
1398 return true;
1399 case bfd_mach_h8300h:
1400 *magicp = H8300HMAGIC;
1401 return true;
1402 }
1403 break;
1404 #endif
1405
1406 #ifdef SH_ARCH_MAGIC_BIG
1407 case bfd_arch_sh:
1408 if (abfd->xvec->byteorder_big_p)
1409 *magicp = SH_ARCH_MAGIC_BIG;
1410 else
1411 *magicp = SH_ARCH_MAGIC_LITTLE;
1412 return true;
1413 break;
1414 #endif
1415
1416 #ifdef SPARCMAGIC
1417 case bfd_arch_sparc:
1418 *magicp = SPARCMAGIC;
1419 #ifdef LYNXOS
1420 /* Just overwrite the usual value if we're doing Lynx. */
1421 *magicp = LYNXCOFFMAGIC;
1422 #endif
1423 return true;
1424 break;
1425 #endif
1426
1427 #ifdef H8500MAGIC
1428 case bfd_arch_h8500:
1429 *magicp = H8500MAGIC;
1430 return true;
1431 break;
1432 #endif
1433 #ifdef A29K_MAGIC_BIG
1434 case bfd_arch_a29k:
1435 if (abfd->xvec->byteorder_big_p)
1436 *magicp = A29K_MAGIC_BIG;
1437 else
1438 *magicp = A29K_MAGIC_LITTLE;
1439 return true;
1440 break;
1441 #endif
1442
1443 #ifdef WE32KMAGIC
1444 case bfd_arch_we32k:
1445 *magicp = WE32KMAGIC;
1446 return true;
1447 break;
1448 #endif
1449
1450 #ifdef U802TOCMAGIC
1451 case bfd_arch_rs6000:
1452 #ifndef PPCMAGIC
1453 case bfd_arch_powerpc:
1454 #endif
1455 *magicp = U802TOCMAGIC;
1456 return true;
1457 break;
1458 #endif
1459
1460 default: /* Unknown architecture */
1461 /* return false; -- fall through to "return false" below, to avoid
1462 "statement never reached" errors on the one below. */
1463 break;
1464 }
1465
1466 return false;
1467 }
1468
1469
1470 static boolean
1471 coff_set_arch_mach (abfd, arch, machine)
1472 bfd * abfd;
1473 enum bfd_architecture arch;
1474 unsigned long machine;
1475 {
1476 unsigned dummy1;
1477 unsigned short dummy2;
1478
1479 if (! bfd_default_set_arch_mach (abfd, arch, machine))
1480 return false;
1481
1482 if (arch != bfd_arch_unknown &&
1483 coff_set_flags (abfd, &dummy1, &dummy2) != true)
1484 return false; /* We can't represent this type */
1485
1486 return true; /* We're easy ... */
1487 }
1488
1489
1490 /* Calculate the file position for each section. */
1491
1492 static void
1493 coff_compute_section_file_positions (abfd)
1494 bfd * abfd;
1495 {
1496 asection *current;
1497 asection *previous = (asection *) NULL;
1498 file_ptr sofar = FILHSZ;
1499
1500 #ifndef I960
1501 file_ptr old_sofar;
1502 #endif
1503 unsigned int count;
1504
1505
1506 #ifdef COFF_IMAGE_WITH_PE
1507 int page_size;
1508 if (coff_data (abfd)->link_info)
1509 {
1510 page_size = pe_data (abfd)->pe_opthdr.FileAlignment;
1511 }
1512 else
1513 page_size = PE_DEF_FILE_ALIGNMENT;
1514 #elif defined (COFF_PAGE_SIZE)
1515 int page_size = COFF_PAGE_SIZE;
1516 #endif
1517
1518 if (bfd_get_start_address (abfd))
1519 {
1520 /* A start address may have been added to the original file. In this
1521 case it will need an optional header to record it. */
1522 abfd->flags |= EXEC_P;
1523 }
1524
1525 if (abfd->flags & EXEC_P)
1526 sofar += AOUTSZ;
1527
1528 sofar += abfd->section_count * SCNHSZ;
1529 for (current = abfd->sections, count = 1;
1530 current != (asection *) NULL;
1531 current = current->next, ++count)
1532 {
1533 current->target_index = count;
1534
1535 /* Only deal with sections which have contents */
1536 if (!(current->flags & SEC_HAS_CONTENTS))
1537 continue;
1538
1539 #ifdef COFF_WITH_PE
1540 /* Do not include the .junk section. This is where we collect section
1541 data which we don't need. This is mainly the MS .debug$ data which
1542 stores codeview debug data. */
1543 if (strcmp (current->name, ".junk") == 0)
1544 {
1545 continue;
1546 }
1547 #endif
1548
1549 /* Align the sections in the file to the same boundary on
1550 which they are aligned in virtual memory. I960 doesn't
1551 do this (FIXME) so we can stay in sync with Intel. 960
1552 doesn't yet page from files... */
1553 #ifndef I960
1554 {
1555 /* make sure this section is aligned on the right boundary - by
1556 padding the previous section up if necessary */
1557
1558 old_sofar = sofar;
1559 sofar = BFD_ALIGN (sofar, 1 << current->alignment_power);
1560 if (previous != (asection *) NULL)
1561 {
1562 previous->_raw_size += sofar - old_sofar;
1563 }
1564 }
1565
1566 #endif
1567
1568 /* In demand paged files the low order bits of the file offset
1569 must match the low order bits of the virtual address. */
1570 #ifdef COFF_PAGE_SIZE
1571 if ((abfd->flags & D_PAGED) != 0
1572 && (current->flags & SEC_ALLOC) != 0)
1573 sofar += (current->vma - sofar) % page_size;
1574 #endif
1575 current->filepos = sofar;
1576
1577 #ifdef COFF_IMAGE_WITH_PE
1578 /* With PE we have to pad each section to be a multiple of its page size
1579 too, and remember both sizes. Cooked_size becomes very useful. */
1580 current->_cooked_size = current->_raw_size;
1581 current->_raw_size = (current->_raw_size + page_size -1) & -page_size;
1582 #endif
1583
1584 sofar += current->_raw_size;
1585
1586 #ifndef I960
1587 /* make sure that this section is of the right size too */
1588 old_sofar = sofar;
1589 sofar = BFD_ALIGN (sofar, 1 << current->alignment_power);
1590 current->_raw_size += sofar - old_sofar;
1591 #endif
1592
1593 #ifdef _LIB
1594 /* Force .lib sections to start at zero. The vma is then
1595 incremented in coff_set_section_contents. This is right for
1596 SVR3.2. */
1597 if (strcmp (current->name, _LIB) == 0)
1598 bfd_set_section_vma (abfd, current, 0);
1599 #endif
1600
1601 previous = current;
1602 }
1603
1604 obj_relocbase (abfd) = sofar;
1605 abfd->output_has_begun = true;
1606
1607 }
1608
1609 #ifndef RS6000COFF_C
1610
1611 /* If .file, .text, .data, .bss symbols are missing, add them. */
1612 /* @@ Should we only be adding missing symbols, or overriding the aux
1613 values for existing section symbols? */
1614 static boolean
1615 coff_add_missing_symbols (abfd)
1616 bfd *abfd;
1617 {
1618 unsigned int nsyms = bfd_get_symcount (abfd);
1619 asymbol **sympp = abfd->outsymbols;
1620 asymbol **sympp2;
1621 unsigned int i;
1622 int need_text = 1, need_data = 1, need_bss = 1, need_file = 1;
1623
1624 for (i = 0; i < nsyms; i++)
1625 {
1626 coff_symbol_type *csym = coff_symbol_from (abfd, sympp[i]);
1627 CONST char *name;
1628 if (csym)
1629 {
1630 /* only do this if there is a coff representation of the input
1631 symbol */
1632 if (csym->native && csym->native->u.syment.n_sclass == C_FILE)
1633 {
1634 need_file = 0;
1635 continue;
1636 }
1637 name = csym->symbol.name;
1638 if (!name)
1639 continue;
1640 if (!strcmp (name, _TEXT))
1641 need_text = 0;
1642 #ifdef APOLLO_M68
1643 else if (!strcmp (name, ".wtext"))
1644 need_text = 0;
1645 #endif
1646 else if (!strcmp (name, _DATA))
1647 need_data = 0;
1648 else if (!strcmp (name, _BSS))
1649 need_bss = 0;
1650 }
1651 }
1652 /* Now i == bfd_get_symcount (abfd). */
1653 /* @@ For now, don't deal with .file symbol. */
1654 need_file = 0;
1655
1656 if (!need_text && !need_data && !need_bss && !need_file)
1657 return true;
1658 nsyms += need_text + need_data + need_bss + need_file;
1659 sympp2 = (asymbol **) bfd_alloc_by_size_t (abfd, nsyms * sizeof (asymbol *));
1660 if (!sympp2)
1661 {
1662 bfd_set_error (bfd_error_no_memory);
1663 return false;
1664 }
1665 memcpy (sympp2, sympp, i * sizeof (asymbol *));
1666 if (need_file)
1667 {
1668 /* @@ Generate fake .file symbol, in sympp2[i], and increment i. */
1669 abort ();
1670 }
1671 if (need_text)
1672 sympp2[i++] = coff_section_symbol (abfd, _TEXT);
1673 if (need_data)
1674 sympp2[i++] = coff_section_symbol (abfd, _DATA);
1675 if (need_bss)
1676 sympp2[i++] = coff_section_symbol (abfd, _BSS);
1677 BFD_ASSERT (i == nsyms);
1678 bfd_set_symtab (abfd, sympp2, nsyms);
1679 return true;
1680 }
1681
1682 #endif /* ! defined (RS6000COFF_C) */
1683
1684
1685
1686 /* SUPPRESS 558 */
1687 /* SUPPRESS 529 */
1688 static boolean
1689 coff_write_object_contents (abfd)
1690 bfd * abfd;
1691 {
1692 asection *current;
1693 boolean hasrelocs = false;
1694 boolean haslinno = false;
1695 file_ptr reloc_base;
1696 file_ptr lineno_base;
1697 file_ptr sym_base;
1698 unsigned long reloc_size = 0;
1699 unsigned long lnno_size = 0;
1700 asection *text_sec = NULL;
1701 asection *data_sec = NULL;
1702 asection *bss_sec = NULL;
1703
1704 struct internal_filehdr internal_f;
1705 struct internal_aouthdr internal_a;
1706
1707 bfd_set_error (bfd_error_system_call);
1708
1709 if (abfd->output_has_begun == false)
1710 coff_compute_section_file_positions (abfd);
1711
1712 reloc_base = obj_relocbase (abfd);
1713
1714 /* Make a pass through the symbol table to count line number entries and
1715 put them into the correct asections */
1716
1717 lnno_size = coff_count_linenumbers (abfd) * LINESZ;
1718
1719 /* Work out the size of the reloc and linno areas */
1720
1721 for (current = abfd->sections; current != NULL; current =
1722 current->next)
1723 reloc_size += current->reloc_count * RELSZ;
1724
1725 lineno_base = reloc_base + reloc_size;
1726 sym_base = lineno_base + lnno_size;
1727
1728 /* Indicate in each section->line_filepos its actual file address */
1729 for (current = abfd->sections; current != NULL; current =
1730 current->next)
1731 {
1732 if (current->lineno_count)
1733 {
1734 current->line_filepos = lineno_base;
1735 current->moving_line_filepos = lineno_base;
1736 lineno_base += current->lineno_count * LINESZ;
1737 }
1738 else
1739 {
1740 current->line_filepos = 0;
1741 }
1742 if (current->reloc_count)
1743 {
1744 current->rel_filepos = reloc_base;
1745 reloc_base += current->reloc_count * RELSZ;
1746 }
1747 else
1748 {
1749 current->rel_filepos = 0;
1750 }
1751 }
1752
1753 /* Write section headers to the file. */
1754 internal_f.f_nscns = 0;
1755
1756 if (bfd_seek (abfd,
1757 (file_ptr) ((abfd->flags & EXEC_P) ?
1758 (FILHSZ + AOUTSZ) : FILHSZ),
1759 SEEK_SET) != 0)
1760 return false;
1761
1762 for (current = abfd->sections;
1763 current != NULL;
1764 current = current->next)
1765 {
1766 struct internal_scnhdr section;
1767
1768 #ifdef COFF_WITH_PE
1769 /* Do not include the .junk section. This is where we collect section
1770 data which we don't need. This is mainly the MS .debug$ data which
1771 stores codeview debug data. */
1772 if (strcmp (current->name, ".junk") == 0)
1773 {
1774 continue;
1775 }
1776
1777 /* If we've got a .reloc section, remember. */
1778
1779 if (strcmp (current->name, ".reloc") == 0)
1780 {
1781 pe_data (abfd)->has_reloc_section = 1;
1782 }
1783 #endif
1784 internal_f.f_nscns++;
1785 strncpy (&(section.s_name[0]), current->name, 8);
1786 #ifdef _LIB
1787 /* Always set s_vaddr of .lib to 0. This is right for SVR3.2
1788 Ian Taylor <ian@cygnus.com>. */
1789 if (strcmp (current->name, _LIB) == 0)
1790 section.s_vaddr = 0;
1791 else
1792 #endif
1793 section.s_vaddr = current->lma;
1794 section.s_paddr = current->lma;
1795 section.s_size = current->_raw_size;
1796
1797 #ifdef COFF_WITH_PE
1798 section.s_paddr = current->_cooked_size;
1799 #endif
1800
1801 /*
1802 If this section has no size or is unloadable then the scnptr
1803 will be 0 too
1804 */
1805 if (current->_raw_size == 0 ||
1806 (current->flags & (SEC_LOAD | SEC_HAS_CONTENTS)) == 0)
1807 {
1808 section.s_scnptr = 0;
1809 }
1810 else
1811 {
1812 section.s_scnptr = current->filepos;
1813 }
1814 section.s_relptr = current->rel_filepos;
1815 section.s_lnnoptr = current->line_filepos;
1816 section.s_nreloc = current->reloc_count;
1817 section.s_nlnno = current->lineno_count;
1818 if (current->reloc_count != 0)
1819 hasrelocs = true;
1820 if (current->lineno_count != 0)
1821 haslinno = true;
1822
1823 section.s_flags = sec_to_styp_flags (current->name, current->flags);
1824
1825 if (!strcmp (current->name, _TEXT))
1826 {
1827 text_sec = current;
1828 }
1829 else if (!strcmp (current->name, _DATA))
1830 {
1831 data_sec = current;
1832 }
1833 else if (!strcmp (current->name, _BSS))
1834 {
1835 bss_sec = current;
1836 }
1837
1838 #ifdef I960
1839 section.s_align = (current->alignment_power
1840 ? 1 << current->alignment_power
1841 : 0);
1842
1843 #endif
1844
1845 #ifdef COFF_IMAGE_WITH_PE
1846 /* suppress output of the sections if they are null. ld includes
1847 the bss and data sections even if there is no size assigned
1848 to them. NT loader doesn't like it if these section headers are
1849 included if the sections themselves are not needed */
1850 if (section.s_size == 0)
1851 internal_f.f_nscns--;
1852 else
1853 #endif
1854 {
1855 SCNHDR buff;
1856 if (coff_swap_scnhdr_out (abfd, &section, &buff) == 0
1857 || bfd_write ((PTR) (&buff), 1, SCNHSZ, abfd) != SCNHSZ)
1858 return false;
1859 }
1860 }
1861
1862
1863
1864 /* OK, now set up the filehdr... */
1865
1866 /* Don't include the internal abs section in the section count */
1867
1868 /*
1869 We will NOT put a fucking timestamp in the header here. Every time you
1870 put it back, I will come in and take it out again. I'm sorry. This
1871 field does not belong here. We fill it with a 0 so it compares the
1872 same but is not a reasonable time. -- gnu@cygnus.com
1873 */
1874 internal_f.f_timdat = 0;
1875
1876 internal_f.f_flags = 0;
1877
1878 if (abfd->flags & EXEC_P)
1879 internal_f.f_opthdr = AOUTSZ;
1880 else
1881 internal_f.f_opthdr = 0;
1882
1883 if (!hasrelocs)
1884 internal_f.f_flags |= F_RELFLG;
1885 if (!haslinno)
1886 internal_f.f_flags |= F_LNNO;
1887 if (abfd->flags & EXEC_P)
1888 internal_f.f_flags |= F_EXEC;
1889
1890 if (!abfd->xvec->byteorder_big_p)
1891 internal_f.f_flags |= F_AR32WR;
1892 else
1893 internal_f.f_flags |= F_AR32W;
1894
1895 /*
1896 FIXME, should do something about the other byte orders and
1897 architectures.
1898 */
1899
1900 memset (&internal_a, 0, sizeof internal_a);
1901
1902 /* Set up architecture-dependent stuff */
1903
1904 {
1905 unsigned int magic = 0;
1906 unsigned short flags = 0;
1907 coff_set_flags (abfd, &magic, &flags);
1908 internal_f.f_magic = magic;
1909 internal_f.f_flags |= flags;
1910 /* ...and the "opt"hdr... */
1911
1912 #ifdef A29K
1913 #ifdef ULTRA3 /* NYU's machine */
1914 /* FIXME: This is a bogus check. I really want to see if there
1915 * is a .shbss or a .shdata section, if so then set the magic
1916 * number to indicate a shared data executable.
1917 */
1918 if (internal_f.f_nscns >= 7)
1919 internal_a.magic = SHMAGIC; /* Shared magic */
1920 else
1921 #endif /* ULTRA3 */
1922 internal_a.magic = NMAGIC; /* Assume separate i/d */
1923 #define __A_MAGIC_SET__
1924 #endif /* A29K */
1925 #ifdef I960
1926 internal_a.magic = (magic == I960ROMAGIC ? NMAGIC : OMAGIC);
1927 #define __A_MAGIC_SET__
1928 #endif /* I960 */
1929 #if M88
1930 #define __A_MAGIC_SET__
1931 internal_a.magic = PAGEMAGICBCS;
1932 #endif /* M88 */
1933
1934 #if APOLLO_M68
1935 #define __A_MAGIC_SET__
1936 internal_a.magic = APOLLO_COFF_VERSION_NUMBER;
1937 #endif
1938
1939 #if defined(M68) || defined(WE32K) || defined(M68K)
1940 #define __A_MAGIC_SET__
1941 #if defined(LYNXOS)
1942 internal_a.magic = LYNXCOFFMAGIC;
1943 #endif /* LYNXOS */
1944 #endif /* M68 || WE32K || M68K */
1945
1946 #if defined(ARM)
1947 #define __A_MAGIC_SET__
1948 internal_a.magic = ZMAGIC;
1949 #endif
1950 #if defined(PPC)
1951 #define __A_MAGIC_SET__
1952 internal_a.magic = PPCMAGIC;
1953 #endif
1954 #if defined(I386)
1955 #define __A_MAGIC_SET__
1956 #if defined(LYNXOS)
1957 internal_a.magic = LYNXCOFFMAGIC;
1958 #else /* LYNXOS */
1959 internal_a.magic = ZMAGIC;
1960 #endif /* LYNXOS */
1961 #endif /* I386 */
1962
1963 #if defined(SPARC)
1964 #define __A_MAGIC_SET__
1965 #if defined(LYNXOS)
1966 internal_a.magic = LYNXCOFFMAGIC;
1967 #endif /* LYNXOS */
1968 #endif /* SPARC */
1969
1970 #if RS6000COFF_C
1971 #define __A_MAGIC_SET__
1972 internal_a.magic = (abfd->flags & D_PAGED) ? RS6K_AOUTHDR_ZMAGIC :
1973 (abfd->flags & WP_TEXT) ? RS6K_AOUTHDR_NMAGIC :
1974 RS6K_AOUTHDR_OMAGIC;
1975 #endif
1976
1977 #ifndef __A_MAGIC_SET__
1978 #include "Your aouthdr magic number is not being set!"
1979 #else
1980 #undef __A_MAGIC_SET__
1981 #endif
1982 }
1983
1984 /* FIXME: Does anybody ever set this to another value? */
1985 internal_a.vstamp = 0;
1986
1987 /* Now should write relocs, strings, syms */
1988 obj_sym_filepos (abfd) = sym_base;
1989
1990 if (bfd_get_symcount (abfd) != 0)
1991 {
1992 int firstundef;
1993 #ifndef RS6000COFF_C
1994 if (!coff_add_missing_symbols (abfd))
1995 return false;
1996 #endif
1997 if (!coff_renumber_symbols (abfd, &firstundef))
1998 return false;
1999 coff_mangle_symbols (abfd);
2000 if (! coff_write_symbols (abfd))
2001 return false;
2002 if (! coff_write_linenumbers (abfd))
2003 return false;
2004 if (! coff_write_relocs (abfd, firstundef))
2005 return false;
2006 }
2007
2008 /* If bfd_get_symcount (abfd) != 0, then we are not using the COFF
2009 backend linker, and obj_raw_syment_count is not valid until after
2010 coff_write_symbols is called. */
2011 if (obj_raw_syment_count (abfd) != 0)
2012 internal_f.f_symptr = sym_base;
2013 else
2014 {
2015 internal_f.f_symptr = 0;
2016 internal_f.f_flags |= F_LSYMS;
2017 }
2018
2019 if (text_sec)
2020 {
2021 internal_a.tsize = bfd_get_section_size_before_reloc (text_sec);
2022 internal_a.text_start = internal_a.tsize ? text_sec->vma : 0;
2023 }
2024 if (data_sec)
2025 {
2026 internal_a.dsize = bfd_get_section_size_before_reloc (data_sec);
2027 internal_a.data_start = internal_a.dsize ? data_sec->vma : 0;
2028 }
2029 if (bss_sec)
2030 {
2031 internal_a.bsize = bfd_get_section_size_before_reloc (bss_sec);
2032 }
2033
2034 internal_a.entry = bfd_get_start_address (abfd);
2035 internal_f.f_nsyms = obj_raw_syment_count (abfd);
2036
2037 /* now write them */
2038 if (bfd_seek (abfd, (file_ptr) 0, SEEK_SET) != 0)
2039 return false;
2040 {
2041 FILHDR buff;
2042 coff_swap_filehdr_out (abfd, (PTR) & internal_f, (PTR) & buff);
2043 if (bfd_write ((PTR) & buff, 1, FILHSZ, abfd) != FILHSZ)
2044 return false;
2045 }
2046 if (abfd->flags & EXEC_P)
2047 {
2048 AOUTHDR buff;
2049 coff_swap_aouthdr_out (abfd, (PTR) & internal_a, (PTR) & buff);
2050 if (bfd_write ((PTR) & buff, 1, AOUTSZ, abfd) != AOUTSZ)
2051 return false;
2052 }
2053
2054 return true;
2055 }
2056
2057 static boolean
2058 coff_set_section_contents (abfd, section, location, offset, count)
2059 bfd * abfd;
2060 sec_ptr section;
2061 PTR location;
2062 file_ptr offset;
2063 bfd_size_type count;
2064 {
2065 if (abfd->output_has_begun == false) /* set by bfd.c handler */
2066 coff_compute_section_file_positions (abfd);
2067
2068 #ifdef _LIB
2069 /* If this is a .lib section, bump the vma address so that it
2070 winds up being the number of .lib sections output. This is
2071 right for SVR3.2. Shared libraries should probably get more
2072 generic support. Ian Taylor <ian@cygnus.com>. */
2073 if (strcmp (section->name, _LIB) == 0)
2074 ++section->lma;
2075 #endif
2076
2077 /* Don't write out bss sections - one way to do this is to
2078 see if the filepos has not been set. */
2079 if (section->filepos == 0)
2080 return true;
2081
2082 if (bfd_seek (abfd, (file_ptr) (section->filepos + offset), SEEK_SET) != 0)
2083 return false;
2084
2085 if (count != 0)
2086 {
2087 return (bfd_write (location, 1, count, abfd) == count) ? true : false;
2088 }
2089 return true;
2090 }
2091 #if 0
2092 static boolean
2093 coff_close_and_cleanup (abfd)
2094 bfd *abfd;
2095 {
2096 if (!bfd_read_p (abfd))
2097 switch (abfd->format)
2098 {
2099 case bfd_archive:
2100 if (!_bfd_write_archive_contents (abfd))
2101 return false;
2102 break;
2103 case bfd_object:
2104 if (!coff_write_object_contents (abfd))
2105 return false;
2106 break;
2107 default:
2108 bfd_set_error (bfd_error_invalid_operation);
2109 return false;
2110 }
2111
2112 /* We depend on bfd_close to free all the memory on the obstack. */
2113 /* FIXME if bfd_release is not using obstacks! */
2114 return true;
2115 }
2116
2117 #endif
2118
2119 static PTR
2120 buy_and_read (abfd, where, seek_direction, size)
2121 bfd *abfd;
2122 file_ptr where;
2123 int seek_direction;
2124 size_t size;
2125 {
2126 PTR area = (PTR) bfd_alloc (abfd, size);
2127 if (!area)
2128 {
2129 bfd_set_error (bfd_error_no_memory);
2130 return (NULL);
2131 }
2132 if (bfd_seek (abfd, where, seek_direction) != 0
2133 || bfd_read (area, 1, size, abfd) != size)
2134 return (NULL);
2135 return (area);
2136 } /* buy_and_read() */
2137
2138 /*
2139 SUBSUBSECTION
2140 Reading linenumbers
2141
2142 Creating the linenumber table is done by reading in the entire
2143 coff linenumber table, and creating another table for internal use.
2144
2145 A coff linenumber table is structured so that each function
2146 is marked as having a line number of 0. Each line within the
2147 function is an offset from the first line in the function. The
2148 base of the line number information for the table is stored in
2149 the symbol associated with the function.
2150
2151 The information is copied from the external to the internal
2152 table, and each symbol which marks a function is marked by
2153 pointing its...
2154
2155 How does this work ?
2156
2157 */
2158
2159 static boolean
2160 coff_slurp_line_table (abfd, asect)
2161 bfd *abfd;
2162 asection *asect;
2163 {
2164 LINENO *native_lineno;
2165 alent *lineno_cache;
2166
2167 BFD_ASSERT (asect->lineno == (alent *) NULL);
2168
2169 native_lineno = (LINENO *) buy_and_read (abfd,
2170 asect->line_filepos,
2171 SEEK_SET,
2172 (size_t) (LINESZ *
2173 asect->lineno_count));
2174 lineno_cache =
2175 (alent *) bfd_alloc (abfd, (size_t) ((asect->lineno_count + 1) * sizeof (alent)));
2176 if (lineno_cache == NULL)
2177 {
2178 bfd_set_error (bfd_error_no_memory);
2179 return false;
2180 }
2181 else
2182 {
2183 unsigned int counter = 0;
2184 alent *cache_ptr = lineno_cache;
2185 LINENO *src = native_lineno;
2186
2187 while (counter < asect->lineno_count)
2188 {
2189 struct internal_lineno dst;
2190 coff_swap_lineno_in (abfd, src, &dst);
2191 cache_ptr->line_number = dst.l_lnno;
2192
2193 if (cache_ptr->line_number == 0)
2194 {
2195 coff_symbol_type *sym =
2196 (coff_symbol_type *) (dst.l_addr.l_symndx
2197 + obj_raw_syments (abfd))->u.syment._n._n_n._n_zeroes;
2198 cache_ptr->u.sym = (asymbol *) sym;
2199 sym->lineno = cache_ptr;
2200 }
2201 else
2202 {
2203 cache_ptr->u.offset = dst.l_addr.l_paddr
2204 - bfd_section_vma (abfd, asect);
2205 } /* If no linenumber expect a symbol index */
2206
2207 cache_ptr++;
2208 src++;
2209 counter++;
2210 }
2211 cache_ptr->line_number = 0;
2212
2213 }
2214 asect->lineno = lineno_cache;
2215 /* FIXME, free native_lineno here, or use alloca or something. */
2216 return true;
2217 }
2218
2219 static boolean
2220 coff_slurp_symbol_table (abfd)
2221 bfd * abfd;
2222 {
2223 combined_entry_type *native_symbols;
2224 coff_symbol_type *cached_area;
2225 unsigned int *table_ptr;
2226
2227 unsigned int number_of_symbols = 0;
2228
2229 if (obj_symbols (abfd))
2230 return true;
2231
2232 /* Read in the symbol table */
2233 if ((native_symbols = coff_get_normalized_symtab (abfd)) == NULL)
2234 {
2235 return (false);
2236 } /* on error */
2237
2238 /* Allocate enough room for all the symbols in cached form */
2239 cached_area = ((coff_symbol_type *)
2240 bfd_alloc (abfd,
2241 (obj_raw_syment_count (abfd)
2242 * sizeof (coff_symbol_type))));
2243
2244 if (cached_area == NULL)
2245 {
2246 bfd_set_error (bfd_error_no_memory);
2247 return false;
2248 } /* on error */
2249 table_ptr = ((unsigned int *)
2250 bfd_alloc (abfd,
2251 (obj_raw_syment_count (abfd)
2252 * sizeof (unsigned int))));
2253
2254 if (table_ptr == NULL)
2255 {
2256 bfd_set_error (bfd_error_no_memory);
2257 return false;
2258 }
2259 else
2260 {
2261 coff_symbol_type *dst = cached_area;
2262 unsigned int last_native_index = obj_raw_syment_count (abfd);
2263 unsigned int this_index = 0;
2264 while (this_index < last_native_index)
2265 {
2266 combined_entry_type *src = native_symbols + this_index;
2267 table_ptr[this_index] = number_of_symbols;
2268 dst->symbol.the_bfd = abfd;
2269
2270 dst->symbol.name = (char *) (src->u.syment._n._n_n._n_offset);
2271 /* We use the native name field to point to the cached field. */
2272 src->u.syment._n._n_n._n_zeroes = (long) dst;
2273 dst->symbol.section = coff_section_from_bfd_index (abfd,
2274 src->u.syment.n_scnum);
2275 dst->symbol.flags = 0;
2276 dst->done_lineno = false;
2277
2278 switch (src->u.syment.n_sclass)
2279 {
2280 #ifdef I960
2281 case C_LEAFEXT:
2282 #if 0
2283 dst->symbol.value = src->u.syment.n_value - dst->symbol.section->vma;
2284 dst->symbol.flags = BSF_EXPORT | BSF_GLOBAL;
2285 dst->symbol.flags |= BSF_NOT_AT_END | BSF_FUNCTION;
2286 #endif
2287 /* Fall through to next case */
2288
2289 #endif
2290
2291 case C_EXT:
2292 #ifdef RS6000COFF_C
2293 case C_HIDEXT:
2294 #endif
2295 #ifdef COFF_WITH_PE
2296 /* PE uses storage class 0x68 to denote a section symbol */
2297 case C_SECTION:
2298 #endif
2299 if ((src->u.syment.n_scnum) == 0)
2300 {
2301 if ((src->u.syment.n_value) == 0)
2302 {
2303 dst->symbol.section = bfd_und_section_ptr;
2304 dst->symbol.value = 0;
2305 }
2306 else
2307 {
2308 dst->symbol.section = bfd_com_section_ptr;
2309 dst->symbol.value = (src->u.syment.n_value);
2310 }
2311 }
2312 else
2313 {
2314 /* Base the value as an index from the base of the
2315 section */
2316
2317 dst->symbol.flags = BSF_EXPORT | BSF_GLOBAL;
2318 dst->symbol.value = (src->u.syment.n_value
2319 - dst->symbol.section->vma);
2320
2321 if (ISFCN ((src->u.syment.n_type)))
2322 {
2323 /* A function ext does not go at the end of a
2324 file. */
2325 dst->symbol.flags |= BSF_NOT_AT_END | BSF_FUNCTION;
2326 }
2327 }
2328
2329 #ifdef RS6000COFF_C
2330 /* A C_HIDEXT symbol is not global. */
2331 if (src->u.syment.n_sclass == C_HIDEXT)
2332 dst->symbol.flags = BSF_LOCAL;
2333
2334 /* If this symbol has a csect aux of type LD, the scnlen
2335 field is actually the index of the containing csect
2336 symbol. We need to pointerize it. */
2337 if (src->u.syment.n_numaux > 0)
2338 {
2339 combined_entry_type *aux;
2340
2341 aux = src + src->u.syment.n_numaux - 1;
2342 if (SMTYP_SMTYP (aux->u.auxent.x_csect.x_smtyp) == XTY_LD)
2343 {
2344 aux->u.auxent.x_csect.x_scnlen.p =
2345 native_symbols + aux->u.auxent.x_csect.x_scnlen.l;
2346 aux->fix_scnlen = 1;
2347 }
2348 }
2349 #endif
2350
2351 break;
2352
2353 case C_STAT: /* static */
2354 #ifdef I960
2355 case C_LEAFSTAT: /* static leaf procedure */
2356 #endif
2357 case C_LABEL: /* label */
2358 if (src->u.syment.n_scnum == -2)
2359 dst->symbol.flags = BSF_DEBUGGING;
2360 else
2361 dst->symbol.flags = BSF_LOCAL;
2362 /*
2363 Base the value as an index from the base of the section, if
2364 there is one
2365 */
2366 if (dst->symbol.section)
2367 dst->symbol.value = (src->u.syment.n_value) -
2368 dst->symbol.section->vma;
2369 else
2370 dst->symbol.value = (src->u.syment.n_value);
2371 break;
2372
2373 case C_MOS: /* member of structure */
2374 case C_EOS: /* end of structure */
2375 #ifdef NOTDEF /* C_AUTOARG has the same value */
2376 #ifdef C_GLBLREG
2377 case C_GLBLREG: /* A29k-specific storage class */
2378 #endif
2379 #endif
2380 case C_REGPARM: /* register parameter */
2381 case C_REG: /* register variable */
2382 #ifdef C_AUTOARG
2383 case C_AUTOARG: /* 960-specific storage class */
2384 #endif
2385 case C_TPDEF: /* type definition */
2386 case C_ARG:
2387 case C_AUTO: /* automatic variable */
2388 case C_FIELD: /* bit field */
2389 case C_ENTAG: /* enumeration tag */
2390 case C_MOE: /* member of enumeration */
2391 case C_MOU: /* member of union */
2392 case C_UNTAG: /* union tag */
2393 dst->symbol.flags = BSF_DEBUGGING;
2394 dst->symbol.value = (src->u.syment.n_value);
2395 break;
2396
2397 case C_FILE: /* file name */
2398 case C_STRTAG: /* structure tag */
2399 #ifdef RS6000COFF_C
2400 case C_BINCL: /* beginning of include file */
2401 case C_EINCL: /* ending of include file */
2402 case C_GSYM:
2403 case C_LSYM:
2404 case C_PSYM:
2405 case C_RSYM:
2406 case C_RPSYM:
2407 case C_STSYM:
2408 case C_DECL:
2409 case C_ENTRY:
2410 case C_FUN:
2411 case C_ESTAT:
2412 #endif
2413 dst->symbol.flags = BSF_DEBUGGING;
2414 dst->symbol.value = (src->u.syment.n_value);
2415 break;
2416
2417 #ifdef RS6000COFF_C
2418 case C_BSTAT:
2419 dst->symbol.flags = BSF_DEBUGGING;
2420 dst->symbol.value = src->u.syment.n_value;
2421
2422 /* The value is actually a symbol index. Save a pointer to
2423 the symbol instead of the index. FIXME: This should use a
2424 union. */
2425 src->u.syment.n_value =
2426 (long) (native_symbols + src->u.syment.n_value);
2427 src->fix_value = 1;
2428 break;
2429 #endif
2430
2431 case C_BLOCK: /* ".bb" or ".eb" */
2432 case C_FCN: /* ".bf" or ".ef" */
2433 case C_EFCN: /* physical end of function */
2434 dst->symbol.flags = BSF_LOCAL;
2435 /*
2436 Base the value as an index from the base of the section
2437 */
2438 dst->symbol.value = (src->u.syment.n_value) - dst->symbol.section->vma;
2439 break;
2440
2441 case C_NULL:
2442 case C_EXTDEF: /* external definition */
2443 case C_ULABEL: /* undefined label */
2444 case C_USTATIC: /* undefined static */
2445 #ifndef COFF_WITH_PE
2446 /* C_LINE in regular coff is 0x68. NT has taken over this storage
2447 class to represent a section symbol */
2448 case C_LINE: /* line # reformatted as symbol table entry */
2449 #endif
2450 case C_ALIAS: /* duplicate tag */
2451 case C_HIDDEN: /* ext symbol in dmert public lib */
2452 default:
2453 (*_bfd_error_handler)
2454 ("%s: Unrecognized storage class %d for %s symbol `%s'",
2455 bfd_get_filename (abfd), src->u.syment.n_sclass,
2456 dst->symbol.section->name, dst->symbol.name);
2457 dst->symbol.flags = BSF_DEBUGGING;
2458 dst->symbol.value = (src->u.syment.n_value);
2459 break;
2460 }
2461
2462 /* BFD_ASSERT(dst->symbol.flags != 0);*/
2463
2464 dst->native = src;
2465
2466 dst->symbol.udata.i = 0;
2467 dst->lineno = (alent *) NULL;
2468 this_index += (src->u.syment.n_numaux) + 1;
2469 dst++;
2470 number_of_symbols++;
2471 } /* walk the native symtab */
2472 } /* bfdize the native symtab */
2473
2474 obj_symbols (abfd) = cached_area;
2475 obj_raw_syments (abfd) = native_symbols;
2476
2477 bfd_get_symcount (abfd) = number_of_symbols;
2478 obj_convert (abfd) = table_ptr;
2479 /* Slurp the line tables for each section too */
2480 {
2481 asection *p;
2482 p = abfd->sections;
2483 while (p)
2484 {
2485 coff_slurp_line_table (abfd, p);
2486 p = p->next;
2487 }
2488 }
2489 return true;
2490 } /* coff_slurp_symbol_table() */
2491
2492 /* Check whether a symbol is globally visible. This is used by the
2493 COFF backend linker code in cofflink.c, since a couple of targets
2494 have globally visible symbols which are not class C_EXT. This
2495 function need not handle the case of n_class == C_EXT. */
2496
2497 #undef OTHER_GLOBAL_CLASS
2498
2499 #ifdef I960
2500 #define OTHER_GLOBAL_CLASS C_LEAFEXT
2501 #endif
2502
2503 #ifdef COFF_WITH_PE
2504 #define OTHER_GLOBAL_CLASS C_SECTION
2505 #endif
2506
2507 #ifdef OTHER_GLOBAL_CLASS
2508
2509 static boolean
2510 coff_sym_is_global (abfd, syment)
2511 bfd *abfd;
2512 struct internal_syment *syment;
2513 {
2514 if (syment->n_sclass == OTHER_GLOBAL_CLASS)
2515 return true;
2516 return false;
2517 }
2518
2519 #undef OTHER_GLOBAL_CLASS
2520
2521 #else /* ! defined (OTHER_GLOBAL_CLASS) */
2522
2523 /* sym_is_global should not be defined if it has nothing to do. */
2524
2525 #define coff_sym_is_global 0
2526
2527 #endif /* ! defined (OTHER_GLOBAL_CLASS) */
2528
2529 /*
2530 SUBSUBSECTION
2531 Reading relocations
2532
2533 Coff relocations are easily transformed into the internal BFD form
2534 (@code{arelent}).
2535
2536 Reading a coff relocation table is done in the following stages:
2537
2538 o Read the entire coff relocation table into memory.
2539
2540 o Process each relocation in turn; first swap it from the
2541 external to the internal form.
2542
2543 o Turn the symbol referenced in the relocation's symbol index
2544 into a pointer into the canonical symbol table.
2545 This table is the same as the one returned by a call to
2546 @code{bfd_canonicalize_symtab}. The back end will call that
2547 routine and save the result if a canonicalization hasn't been done.
2548
2549 o The reloc index is turned into a pointer to a howto
2550 structure, in a back end specific way. For instance, the 386
2551 and 960 use the @code{r_type} to directly produce an index
2552 into a howto table vector; the 88k subtracts a number from the
2553 @code{r_type} field and creates an addend field.
2554
2555
2556 */
2557
2558 #ifndef CALC_ADDEND
2559 #define CALC_ADDEND(abfd, ptr, reloc, cache_ptr) \
2560 { \
2561 coff_symbol_type *coffsym = (coff_symbol_type *) NULL; \
2562 if (ptr && bfd_asymbol_bfd (ptr) != abfd) \
2563 coffsym = (obj_symbols (abfd) \
2564 + (cache_ptr->sym_ptr_ptr - symbols)); \
2565 else if (ptr) \
2566 coffsym = coff_symbol_from (abfd, ptr); \
2567 if (coffsym != (coff_symbol_type *) NULL \
2568 && coffsym->native->u.syment.n_scnum == 0) \
2569 cache_ptr->addend = 0; \
2570 else if (ptr && bfd_asymbol_bfd (ptr) == abfd \
2571 && ptr->section != (asection *) NULL) \
2572 cache_ptr->addend = - (ptr->section->vma + ptr->value); \
2573 else \
2574 cache_ptr->addend = 0; \
2575 }
2576 #endif
2577
2578 static boolean
2579 coff_slurp_reloc_table (abfd, asect, symbols)
2580 bfd * abfd;
2581 sec_ptr asect;
2582 asymbol ** symbols;
2583 {
2584 RELOC *native_relocs;
2585 arelent *reloc_cache;
2586 arelent *cache_ptr;
2587
2588 unsigned int idx;
2589
2590 if (asect->relocation)
2591 return true;
2592 if (asect->reloc_count == 0)
2593 return true;
2594 if (asect->flags & SEC_CONSTRUCTOR)
2595 return true;
2596 if (!coff_slurp_symbol_table (abfd))
2597 return false;
2598 native_relocs =
2599 (RELOC *) buy_and_read (abfd,
2600 asect->rel_filepos,
2601 SEEK_SET,
2602 (size_t) (RELSZ *
2603 asect->reloc_count));
2604 reloc_cache = (arelent *)
2605 bfd_alloc (abfd, (size_t) (asect->reloc_count * sizeof (arelent)));
2606
2607 if (reloc_cache == NULL)
2608 {
2609 bfd_set_error (bfd_error_no_memory);
2610 return false;
2611 }
2612
2613
2614 for (idx = 0; idx < asect->reloc_count; idx++)
2615 {
2616 #ifdef RELOC_PROCESSING
2617 struct internal_reloc dst;
2618 struct external_reloc *src;
2619
2620 cache_ptr = reloc_cache + idx;
2621 src = native_relocs + idx;
2622 coff_swap_reloc_in (abfd, src, &dst);
2623
2624 RELOC_PROCESSING (cache_ptr, &dst, symbols, abfd, asect);
2625 #else
2626 struct internal_reloc dst;
2627 asymbol *ptr;
2628 struct external_reloc *src;
2629
2630 cache_ptr = reloc_cache + idx;
2631 src = native_relocs + idx;
2632
2633 coff_swap_reloc_in (abfd, src, &dst);
2634
2635
2636 cache_ptr->address = dst.r_vaddr;
2637
2638 if (dst.r_symndx != -1)
2639 {
2640 /* @@ Should never be greater than count of symbols! */
2641 if (dst.r_symndx >= obj_conv_table_size (abfd))
2642 abort ();
2643 cache_ptr->sym_ptr_ptr = symbols + obj_convert (abfd)[dst.r_symndx];
2644 ptr = *(cache_ptr->sym_ptr_ptr);
2645 }
2646 else
2647 {
2648 cache_ptr->sym_ptr_ptr = bfd_abs_section_ptr->symbol_ptr_ptr;
2649 ptr = 0;
2650 }
2651
2652 /* The symbols definitions that we have read in have been
2653 relocated as if their sections started at 0. But the offsets
2654 refering to the symbols in the raw data have not been
2655 modified, so we have to have a negative addend to compensate.
2656
2657 Note that symbols which used to be common must be left alone */
2658
2659 /* Calculate any reloc addend by looking at the symbol */
2660 CALC_ADDEND (abfd, ptr, dst, cache_ptr);
2661
2662 cache_ptr->address -= asect->vma;
2663 /* !! cache_ptr->section = (asection *) NULL;*/
2664
2665 /* Fill in the cache_ptr->howto field from dst.r_type */
2666 RTYPE2HOWTO (cache_ptr, &dst);
2667 #endif
2668
2669 }
2670
2671 asect->relocation = reloc_cache;
2672 return true;
2673 }
2674
2675 #ifndef coff_rtype_to_howto
2676 #ifdef RTYPE2HOWTO
2677
2678 /* Get the howto structure for a reloc. This is only used if the file
2679 including this one defines coff_relocate_section to be
2680 _bfd_coff_generic_relocate_section, so it is OK if it does not
2681 always work. It is the responsibility of the including file to
2682 make sure it is reasonable if it is needed. */
2683
2684 static reloc_howto_type *coff_rtype_to_howto
2685 PARAMS ((bfd *, asection *, struct internal_reloc *,
2686 struct coff_link_hash_entry *, struct internal_syment *,
2687 bfd_vma *));
2688
2689 /*ARGSUSED*/
2690 static reloc_howto_type *
2691 coff_rtype_to_howto (abfd, sec, rel, h, sym, addendp)
2692 bfd *abfd;
2693 asection *sec;
2694 struct internal_reloc *rel;
2695 struct coff_link_hash_entry *h;
2696 struct internal_syment *sym;
2697 bfd_vma *addendp;
2698 {
2699 arelent genrel;
2700
2701 RTYPE2HOWTO (&genrel, rel);
2702 return genrel.howto;
2703 }
2704
2705 #else /* ! defined (RTYPE2HOWTO) */
2706
2707 #define coff_rtype_to_howto NULL
2708
2709 #endif /* ! defined (RTYPE2HOWTO) */
2710 #endif /* ! defined (coff_rtype_to_howto) */
2711
2712 /* This is stupid. This function should be a boolean predicate. */
2713 static long
2714 coff_canonicalize_reloc (abfd, section, relptr, symbols)
2715 bfd * abfd;
2716 sec_ptr section;
2717 arelent ** relptr;
2718 asymbol ** symbols;
2719 {
2720 arelent *tblptr = section->relocation;
2721 unsigned int count = 0;
2722
2723
2724 if (section->flags & SEC_CONSTRUCTOR)
2725 {
2726 /* this section has relocs made up by us, they are not in the
2727 file, so take them out of their chain and place them into
2728 the data area provided */
2729 arelent_chain *chain = section->constructor_chain;
2730 for (count = 0; count < section->reloc_count; count++)
2731 {
2732 *relptr++ = &chain->relent;
2733 chain = chain->next;
2734 }
2735
2736 }
2737 else
2738 {
2739 if (! coff_slurp_reloc_table (abfd, section, symbols))
2740 return -1;
2741
2742 tblptr = section->relocation;
2743
2744 for (; count++ < section->reloc_count;)
2745 *relptr++ = tblptr++;
2746
2747
2748 }
2749 *relptr = 0;
2750 return section->reloc_count;
2751 }
2752
2753 #ifdef GNU960
2754 file_ptr
2755 coff_sym_filepos (abfd)
2756 bfd *abfd;
2757 {
2758 return obj_sym_filepos (abfd);
2759 }
2760 #endif
2761
2762 #ifndef coff_reloc16_estimate
2763 #define coff_reloc16_estimate dummy_reloc16_estimate
2764
2765 static int
2766 dummy_reloc16_estimate (abfd, input_section, reloc, shrink, link_info)
2767 bfd *abfd;
2768 asection *input_section;
2769 arelent *reloc;
2770 unsigned int shrink;
2771 struct bfd_link_info *link_info;
2772 {
2773 abort ();
2774 }
2775
2776 #endif
2777
2778 #ifndef coff_reloc16_extra_cases
2779 #define coff_reloc16_extra_cases dummy_reloc16_extra_cases
2780 /* This works even if abort is not declared in any header file. */
2781 static void
2782 dummy_reloc16_extra_cases (abfd, link_info, link_order, reloc, data, src_ptr,
2783 dst_ptr)
2784 bfd *abfd;
2785 struct bfd_link_info *link_info;
2786 struct bfd_link_order *link_order;
2787 arelent *reloc;
2788 bfd_byte *data;
2789 unsigned int *src_ptr;
2790 unsigned int *dst_ptr;
2791 {
2792 abort ();
2793 }
2794 #endif
2795
2796 /* If coff_relocate_section is defined, we can use the optimized COFF
2797 backend linker. Otherwise we must continue to use the old linker. */
2798 #ifdef coff_relocate_section
2799 #ifndef coff_bfd_link_hash_table_create
2800 #define coff_bfd_link_hash_table_create _bfd_coff_link_hash_table_create
2801 #endif
2802 #ifndef coff_bfd_link_add_symbols
2803 #define coff_bfd_link_add_symbols _bfd_coff_link_add_symbols
2804 #endif
2805 #ifndef coff_bfd_final_link
2806 #define coff_bfd_final_link _bfd_coff_final_link
2807 #endif
2808 #else /* ! defined (coff_relocate_section) */
2809 #define coff_relocate_section NULL
2810 #define coff_bfd_link_hash_table_create _bfd_generic_link_hash_table_create
2811 #define coff_bfd_link_add_symbols _bfd_generic_link_add_symbols
2812 #define coff_bfd_final_link _bfd_generic_final_link
2813 #endif /* ! defined (coff_relocate_section) */
2814 #define coff_bfd_link_split_section _bfd_generic_link_split_section
2815
2816 #ifndef coff_start_final_link
2817 #define coff_start_final_link NULL
2818 #endif
2819
2820 #ifndef coff_adjust_symndx
2821 #define coff_adjust_symndx NULL
2822 #endif
2823
2824 static CONST bfd_coff_backend_data bfd_coff_std_swap_table =
2825 {
2826 coff_swap_aux_in, coff_swap_sym_in, coff_swap_lineno_in,
2827 coff_swap_aux_out, coff_swap_sym_out,
2828 coff_swap_lineno_out, coff_swap_reloc_out,
2829 coff_swap_filehdr_out, coff_swap_aouthdr_out,
2830 coff_swap_scnhdr_out,
2831 FILHSZ, AOUTSZ, SCNHSZ, SYMESZ, AUXESZ, RELSZ, LINESZ,
2832 #ifdef COFF_LONG_FILENAMES
2833 true,
2834 #else
2835 false,
2836 #endif
2837 coff_swap_filehdr_in, coff_swap_aouthdr_in, coff_swap_scnhdr_in,
2838 coff_swap_reloc_in, coff_bad_format_hook, coff_set_arch_mach_hook,
2839 coff_mkobject_hook, styp_to_sec_flags, coff_set_alignment_hook,
2840 coff_slurp_symbol_table, symname_in_debug_hook,
2841 coff_reloc16_extra_cases, coff_reloc16_estimate,
2842 coff_sym_is_global, coff_compute_section_file_positions,
2843 coff_start_final_link, coff_relocate_section, coff_rtype_to_howto,
2844 coff_adjust_symndx
2845 };
2846
2847 #define coff_close_and_cleanup _bfd_generic_close_and_cleanup
2848 #define coff_bfd_free_cached_info _bfd_generic_bfd_free_cached_info
2849 #define coff_get_section_contents _bfd_generic_get_section_contents
2850
2851 #ifndef coff_bfd_copy_private_symbol_data
2852 #define coff_bfd_copy_private_symbol_data _bfd_generic_bfd_copy_private_symbol_data
2853 #endif
2854
2855 #ifndef coff_bfd_copy_private_section_data
2856 #define coff_bfd_copy_private_section_data _bfd_generic_bfd_copy_private_section_data
2857 #endif
2858
2859 #ifndef coff_bfd_copy_private_bfd_data
2860 #define coff_bfd_copy_private_bfd_data _bfd_generic_bfd_copy_private_bfd_data
2861 #endif
2862
2863 #define coff_bfd_merge_private_bfd_data _bfd_generic_bfd_merge_private_bfd_data
2864 #define coff_bfd_set_private_flags _bfd_generic_bfd_set_private_flags
2865
2866 #ifndef coff_bfd_print_private_bfd_data
2867 #define coff_bfd_print_private_bfd_data _bfd_generic_bfd_print_private_bfd_data
2868 #endif
2869
2870 #ifndef coff_bfd_is_local_label
2871 #define coff_bfd_is_local_label bfd_generic_is_local_label
2872 #endif
2873 #ifndef coff_read_minisymbols
2874 #define coff_read_minisymbols _bfd_generic_read_minisymbols
2875 #endif
2876 #ifndef coff_minisymbol_to_symbol
2877 #define coff_minisymbol_to_symbol _bfd_generic_minisymbol_to_symbol
2878 #endif
2879
2880 /* The reloc lookup routine must be supplied by each individual COFF
2881 backend. */
2882 #ifndef coff_bfd_reloc_type_lookup
2883 #define coff_bfd_reloc_type_lookup _bfd_norelocs_bfd_reloc_type_lookup
2884 #endif
2885
2886 #ifndef coff_bfd_get_relocated_section_contents
2887 #define coff_bfd_get_relocated_section_contents \
2888 bfd_generic_get_relocated_section_contents
2889 #endif
2890 #ifndef coff_bfd_relax_section
2891 #define coff_bfd_relax_section bfd_generic_relax_section
2892 #endif