1 /* BFD back-end for oasys objects.
2 Copyright 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2001,
3 2002, 2003 Free Software Foundation, Inc.
4 Written by Steve Chamberlain of Cygnus Support, <sac@cygnus.com>.
6 This file is part of BFD, the Binary File Descriptor library.
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2 of the License, or
11 (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
22 #define UNDERSCORE_HACK 1
25 #include "safe-ctype.h"
30 static bfd_boolean oasys_slurp_section_data
31 PARAMS ((bfd
* const));
32 static bfd_boolean oasys_read_record
33 PARAMS ((bfd
*, oasys_record_union_type
*));
34 static bfd_boolean oasys_write_sections
36 static bfd_boolean oasys_write_record
37 PARAMS ((bfd
*, oasys_record_enum_type
, oasys_record_union_type
*, size_t));
38 static bfd_boolean oasys_write_syms
40 static bfd_boolean oasys_write_header
42 static bfd_boolean oasys_write_end
44 static bfd_boolean oasys_write_data
46 static size_t oasys_string_length
47 PARAMS ((oasys_record_union_type
*));
48 static bfd_boolean oasys_slurp_symbol_table
49 PARAMS ((bfd
*const));
50 static long int oasys_get_symtab_upper_bound
51 PARAMS ((bfd
*const));
52 static const bfd_target
*oasys_archive_p
54 static bfd_boolean oasys_mkobject
56 static const bfd_target
*oasys_object_p
58 static void oasys_get_symbol_info
59 PARAMS ((bfd
*, asymbol
*, symbol_info
*));
60 static void oasys_print_symbol
61 PARAMS ((bfd
*, void *, asymbol
*, bfd_print_symbol_type
));
62 static bfd_boolean oasys_new_section_hook
63 PARAMS ((bfd
*, asection
*));
64 static long int oasys_get_reloc_upper_bound
65 PARAMS ((bfd
*, sec_ptr
));
66 static bfd_boolean oasys_get_section_contents
67 PARAMS ((bfd
*, sec_ptr
, void *, file_ptr
, bfd_size_type
));
69 PARAMS ((const void *, const void *));
70 static bfd_boolean oasys_write_object_contents
72 static bfd_boolean oasys_set_section_contents
73 PARAMS ((bfd
*, sec_ptr
, const void *, file_ptr
, bfd_size_type
));
74 static asymbol
*oasys_make_empty_symbol
76 static bfd
*oasys_openr_next_archived_file
77 PARAMS ((bfd
*, bfd
*));
78 static bfd_boolean oasys_find_nearest_line
79 PARAMS ((bfd
*, asection
*, asymbol
**, bfd_vma
,
80 const char **, const char **, unsigned int *));
81 static int oasys_generic_stat_arch_elt
82 PARAMS ((bfd
*, struct stat
*));
83 static int oasys_sizeof_headers
84 PARAMS ((bfd
*, bfd_boolean
));
86 long oasys_canonicalize_symtab
87 PARAMS ((bfd
*, asymbol
**));
88 long oasys_canonicalize_reloc
89 PARAMS ((bfd
*, sec_ptr
, arelent
**, asymbol
**));
91 /* Read in all the section data and relocation stuff too. */
94 oasys_read_record (abfd
, record
)
96 oasys_record_union_type
*record
;
98 bfd_size_type amt
= sizeof (record
->header
);
99 if (bfd_bread ((PTR
) record
, amt
, abfd
) != amt
)
102 amt
= record
->header
.length
- sizeof (record
->header
);
105 if (bfd_bread ((PTR
) ((char *) record
+ sizeof (record
->header
)), amt
, abfd
)
112 oasys_string_length (record
)
113 oasys_record_union_type
*record
;
115 return record
->header
.length
116 - ((char *) record
->symbol
.name
- (char *) record
);
119 /*****************************************************************************/
123 Slurp the symbol table by reading in all the records at the start file
124 till we get to the first section record.
126 We'll sort the symbolss into two lists, defined and undefined. The
127 undefined symbols will be placed into the table according to their
130 We do this by placing all undefined symbols at the front of the table
131 moving in, and the defined symbols at the end of the table moving back.
136 oasys_slurp_symbol_table (abfd
)
139 oasys_record_union_type record
;
140 oasys_data_type
*data
= OASYS_DATA (abfd
);
141 bfd_boolean loop
= TRUE
;
142 asymbol
*dest_defined
;
147 if (data
->symbols
!= (asymbol
*) NULL
)
151 /* Buy enough memory for all the symbols and all the names */
152 amt
= abfd
->symcount
;
153 amt
*= sizeof (asymbol
);
154 data
->symbols
= (asymbol
*) bfd_alloc (abfd
, amt
);
156 amt
= data
->symbol_string_length
;
157 #ifdef UNDERSCORE_HACK
158 /* buy 1 more char for each symbol to keep the underscore in*/
159 amt
+= abfd
->symcount
;
161 data
->strings
= bfd_alloc (abfd
, amt
);
163 if (!data
->symbols
|| !data
->strings
)
166 dest_defined
= data
->symbols
+ abfd
->symcount
- 1;
168 string_ptr
= data
->strings
;
169 if (bfd_seek (abfd
, (file_ptr
) 0, SEEK_SET
) != 0)
174 if (! oasys_read_record (abfd
, &record
))
176 switch (record
.header
.type
)
178 case oasys_record_is_header_enum
:
180 case oasys_record_is_local_enum
:
181 case oasys_record_is_symbol_enum
:
183 int flag
= record
.header
.type
== (int) oasys_record_is_local_enum
?
184 (BSF_LOCAL
) : (BSF_GLOBAL
| BSF_EXPORT
);
187 size_t length
= oasys_string_length (&record
);
188 switch (record
.symbol
.relb
& RELOCATION_TYPE_BITS
)
190 case RELOCATION_TYPE_ABS
:
191 dest
= dest_defined
--;
192 dest
->section
= bfd_abs_section_ptr
;
196 case RELOCATION_TYPE_REL
:
197 dest
= dest_defined
--;
199 OASYS_DATA (abfd
)->sections
[record
.symbol
.relb
&
200 RELOCATION_SECT_BITS
];
201 if (record
.header
.type
== (int) oasys_record_is_local_enum
)
203 dest
->flags
= BSF_LOCAL
;
204 if (dest
->section
== (asection
*) (~0))
206 /* It seems that sometimes internal symbols are tied up, but
207 still get output, even though there is no
218 case RELOCATION_TYPE_UND
:
219 dest
= data
->symbols
+ H_GET_16 (abfd
, record
.symbol
.refno
);
220 dest
->section
= bfd_und_section_ptr
;
222 case RELOCATION_TYPE_COM
:
223 dest
= dest_defined
--;
224 dest
->name
= string_ptr
;
225 dest
->the_bfd
= abfd
;
227 dest
->section
= bfd_com_section_ptr
;
231 dest
= dest_defined
--;
235 dest
->name
= string_ptr
;
236 dest
->the_bfd
= abfd
;
237 dest
->udata
.p
= (PTR
) NULL
;
238 dest
->value
= H_GET_32 (abfd
, record
.symbol
.value
);
240 #ifdef UNDERSCORE_HACK
241 if (record
.symbol
.name
[0] != '_')
247 memcpy (string_ptr
, record
.symbol
.name
, length
);
250 string_ptr
[length
] = 0;
251 string_ptr
+= length
+ 1;
262 oasys_get_symtab_upper_bound (abfd
)
265 if (! oasys_slurp_symbol_table (abfd
))
268 return (abfd
->symcount
+ 1) * (sizeof (oasys_symbol_type
*));
271 extern const bfd_target oasys_vec
;
274 oasys_canonicalize_symtab (abfd
, location
)
279 unsigned int counter
;
280 if (! oasys_slurp_symbol_table (abfd
))
284 symbase
= OASYS_DATA (abfd
)->symbols
;
285 for (counter
= 0; counter
< abfd
->symcount
; counter
++)
287 *(location
++) = symbase
++;
290 return abfd
->symcount
;
293 /***********************************************************************
297 static const bfd_target
*
298 oasys_archive_p (abfd
)
301 oasys_archive_header_type header
;
302 oasys_extarchive_header_type header_ext
;
307 amt
= sizeof (header_ext
);
308 if (bfd_seek (abfd
, (file_ptr
) 0, 0) != 0
309 || bfd_bread ((PTR
) &header_ext
, amt
, abfd
) != amt
)
311 if (bfd_get_error () != bfd_error_system_call
)
312 bfd_set_error (bfd_error_wrong_format
);
316 header
.version
= H_GET_32 (abfd
, header_ext
.version
);
317 header
.mod_count
= H_GET_32 (abfd
, header_ext
.mod_count
);
318 header
.mod_tbl_offset
= H_GET_32 (abfd
, header_ext
.mod_tbl_offset
);
319 header
.sym_tbl_size
= H_GET_32 (abfd
, header_ext
.sym_tbl_size
);
320 header
.sym_count
= H_GET_32 (abfd
, header_ext
.sym_count
);
321 header
.sym_tbl_offset
= H_GET_32 (abfd
, header_ext
.sym_tbl_offset
);
322 header
.xref_count
= H_GET_32 (abfd
, header_ext
.xref_count
);
323 header
.xref_lst_offset
= H_GET_32 (abfd
, header_ext
.xref_lst_offset
);
326 There isn't a magic number in an Oasys archive, so the best we
327 can do to verify reasonableness is to make sure that the values in
328 the header are too weird
331 if (header
.version
> 10000 ||
332 header
.mod_count
> 10000 ||
333 header
.sym_count
> 100000 ||
334 header
.xref_count
> 100000)
335 return (const bfd_target
*) NULL
;
338 That all worked, let's buy the space for the header and read in
342 oasys_ar_data_type
*ar
;
343 oasys_module_info_type
*module
;
344 oasys_module_table_type record
;
346 amt
= sizeof (oasys_ar_data_type
);
347 ar
= (oasys_ar_data_type
*) bfd_alloc (abfd
, amt
);
349 amt
= header
.mod_count
;
350 amt
*= sizeof (oasys_module_info_type
);
351 module
= (oasys_module_info_type
*) bfd_alloc (abfd
, amt
);
356 abfd
->tdata
.oasys_ar_data
= ar
;
358 ar
->module_count
= header
.mod_count
;
360 filepos
= header
.mod_tbl_offset
;
361 for (i
= 0; i
< header
.mod_count
; i
++)
363 if (bfd_seek (abfd
, filepos
, SEEK_SET
) != 0)
366 /* There are two ways of specifying the archive header */
370 oasys_extmodule_table_type_a_type record_ext
;
372 amt
= sizeof (record_ext
);
373 if (bfd_bread ((PTR
) &record_ext
, amt
, abfd
) != amt
)
376 record
.mod_size
= H_GET_32 (abfd
, record_ext
.mod_size
);
377 record
.file_offset
= H_GET_32 (abfd
, record_ext
.file_offset
);
379 record
.dep_count
= H_GET_32 (abfd
, record_ext
.dep_count
);
380 record
.depee_count
= H_GET_32 (abfd
, record_ext
.depee_count
);
381 record
.sect_count
= H_GET_32 (abfd
, record_ext
.sect_count
);
383 module
[i
].name
= bfd_alloc (abfd
, (bfd_size_type
) 33);
387 memcpy (module
[i
].name
, record_ext
.mod_name
, 33);
389 sizeof (record_ext
) +
390 record
.dep_count
* 4 +
391 record
.depee_count
* 4 +
392 record
.sect_count
* 8 + 187;
396 oasys_extmodule_table_type_b_type record_ext
;
398 amt
= sizeof (record_ext
);
399 if (bfd_bread ((PTR
) &record_ext
, amt
, abfd
) != amt
)
402 record
.mod_size
= H_GET_32 (abfd
, record_ext
.mod_size
);
403 record
.file_offset
= H_GET_32 (abfd
, record_ext
.file_offset
);
405 record
.dep_count
= H_GET_32 (abfd
, record_ext
.dep_count
);
406 record
.depee_count
= H_GET_32 (abfd
, record_ext
.depee_count
);
407 record
.sect_count
= H_GET_32 (abfd
, record_ext
.sect_count
);
408 record
.module_name_size
= H_GET_32 (abfd
,
409 record_ext
.mod_name_length
);
411 amt
= record
.module_name_size
;
412 module
[i
].name
= bfd_alloc (abfd
, amt
+ 1);
415 if (bfd_bread ((PTR
) module
[i
].name
, amt
, abfd
) != amt
)
417 module
[i
].name
[record
.module_name_size
] = 0;
418 filepos
+= (sizeof (record_ext
)
419 + record
.dep_count
* 4
420 + record
.module_name_size
+ 1);
423 module
[i
].size
= record
.mod_size
;
424 module
[i
].pos
= record
.file_offset
;
432 oasys_mkobject (abfd
)
435 bfd_size_type amt
= sizeof (oasys_data_type
);
436 abfd
->tdata
.oasys_obj_data
= (oasys_data_type
*) bfd_alloc (abfd
, amt
);
437 return abfd
->tdata
.oasys_obj_data
!= NULL
;
441 static const bfd_target
*
442 oasys_object_p (abfd
)
445 oasys_data_type
*oasys
;
446 oasys_data_type
*save
= OASYS_DATA (abfd
);
447 bfd_boolean loop
= TRUE
;
448 bfd_boolean had_usefull
= FALSE
;
450 abfd
->tdata
.oasys_obj_data
= 0;
451 oasys_mkobject (abfd
);
452 oasys
= OASYS_DATA (abfd
);
453 memset ((PTR
) oasys
->sections
, 0xff, sizeof (oasys
->sections
));
455 /* Point to the start of the file */
456 if (bfd_seek (abfd
, (file_ptr
) 0, SEEK_SET
) != 0)
458 oasys
->symbol_string_length
= 0;
459 /* Inspect the records, but only keep the section info -
460 remember the size of the symbols
462 oasys
->first_data_record
= 0;
465 oasys_record_union_type record
;
466 if (! oasys_read_record (abfd
, &record
))
468 if ((size_t) record
.header
.length
< (size_t) sizeof (record
.header
))
472 switch ((oasys_record_enum_type
) (record
.header
.type
))
474 case oasys_record_is_header_enum
:
477 case oasys_record_is_symbol_enum
:
478 case oasys_record_is_local_enum
:
479 /* Count symbols and remember their size for a future malloc */
481 oasys
->symbol_string_length
+= 1 + oasys_string_length (&record
);
484 case oasys_record_is_section_enum
:
488 unsigned int section_number
;
489 if (record
.section
.header
.length
!= sizeof (record
.section
))
493 buffer
= bfd_alloc (abfd
, (bfd_size_type
) 3);
496 section_number
= record
.section
.relb
& RELOCATION_SECT_BITS
;
497 sprintf (buffer
, "%u", section_number
);
498 s
= bfd_make_section (abfd
, buffer
);
499 oasys
->sections
[section_number
] = s
;
500 switch (record
.section
.relb
& RELOCATION_TYPE_BITS
)
502 case RELOCATION_TYPE_ABS
:
503 case RELOCATION_TYPE_REL
:
505 case RELOCATION_TYPE_UND
:
506 case RELOCATION_TYPE_COM
:
510 s
->_raw_size
= H_GET_32 (abfd
, record
.section
.value
);
511 s
->vma
= H_GET_32 (abfd
, record
.section
.vma
);
516 case oasys_record_is_data_enum
:
517 oasys
->first_data_record
= bfd_tell (abfd
) - record
.header
.length
;
518 case oasys_record_is_debug_enum
:
519 case oasys_record_is_module_enum
:
520 case oasys_record_is_named_section_enum
:
521 case oasys_record_is_end_enum
:
530 oasys
->symbols
= (asymbol
*) NULL
;
532 Oasys support several architectures, but I can't see a simple way
533 to discover which one is in a particular file - we'll guess
535 bfd_default_set_arch_mach (abfd
, bfd_arch_m68k
, 0);
536 if (abfd
->symcount
!= 0)
538 abfd
->flags
|= HAS_SYMS
;
542 We don't know if a section has data until we've read it..
545 oasys_slurp_section_data (abfd
);
551 (void) bfd_release (abfd
, oasys
);
552 abfd
->tdata
.oasys_obj_data
= save
;
553 return (const bfd_target
*) NULL
;
558 oasys_get_symbol_info (ignore_abfd
, symbol
, ret
)
559 bfd
*ignore_abfd ATTRIBUTE_UNUSED
;
563 bfd_symbol_info (symbol
, ret
);
564 if (!symbol
->section
)
565 ret
->type
= (symbol
->flags
& BSF_LOCAL
) ? 'a' : 'A';
569 oasys_print_symbol (abfd
, afile
, symbol
, how
)
573 bfd_print_symbol_type how
;
575 FILE *file
= (FILE *) afile
;
579 case bfd_print_symbol_name
:
580 case bfd_print_symbol_more
:
581 fprintf (file
, "%s", symbol
->name
);
583 case bfd_print_symbol_all
:
585 const char *section_name
= symbol
->section
== (asection
*) NULL
?
586 (const char *) "*abs" : symbol
->section
->name
;
588 bfd_print_symbol_vandf (abfd
, (PTR
) file
, symbol
);
590 fprintf (file
, " %-5s %s",
598 The howto table is build using the top two bits of a reloc byte to
599 index into it. The bits are PCREL,WORD/LONG
601 static reloc_howto_type howto_table
[] =
604 HOWTO (0, 0, 1, 16, FALSE
, 0, complain_overflow_bitfield
, 0, "abs16", TRUE
, 0x0000ffff, 0x0000ffff, FALSE
),
605 HOWTO (0, 0, 2, 32, FALSE
, 0, complain_overflow_bitfield
, 0, "abs32", TRUE
, 0xffffffff, 0xffffffff, FALSE
),
606 HOWTO (0, 0, 1, 16, TRUE
, 0, complain_overflow_signed
, 0, "pcrel16", TRUE
, 0x0000ffff, 0x0000ffff, FALSE
),
607 HOWTO (0, 0, 2, 32, TRUE
, 0, complain_overflow_signed
, 0, "pcrel32", TRUE
, 0xffffffff, 0xffffffff, FALSE
)
610 /* Read in all the section data and relocation stuff too */
612 oasys_slurp_section_data (abfd
)
615 oasys_record_union_type record
;
616 oasys_data_type
*data
= OASYS_DATA (abfd
);
617 bfd_boolean loop
= TRUE
;
618 oasys_per_section_type
*per
;
622 /* See if the data has been slurped already .. */
623 for (s
= abfd
->sections
; s
!= (asection
*) NULL
; s
= s
->next
)
625 per
= oasys_per_section (s
);
626 if (per
->initialized
)
630 if (data
->first_data_record
== 0)
633 if (bfd_seek (abfd
, data
->first_data_record
, SEEK_SET
) != 0)
637 if (! oasys_read_record (abfd
, &record
))
639 switch (record
.header
.type
)
641 case oasys_record_is_header_enum
:
643 case oasys_record_is_data_enum
:
646 bfd_byte
*src
= record
.data
.data
;
647 bfd_byte
*end_src
= ((bfd_byte
*) & record
) + record
.header
.length
;
649 bfd_byte
*dst_base_ptr
;
653 data
->sections
[record
.data
.relb
& RELOCATION_SECT_BITS
];
656 per
= oasys_per_section (section
);
658 if (! per
->initialized
)
660 per
->data
= (bfd_byte
*) bfd_zalloc (abfd
, section
->_raw_size
);
664 = (oasys_reloc_type
**) §ion
->relocation
;
665 per
->had_vma
= FALSE
;
666 per
->initialized
= TRUE
;
667 section
->reloc_count
= 0;
668 section
->flags
= SEC_ALLOC
;
671 dst_offset
= H_GET_32 (abfd
, record
.data
.addr
);
674 /* Take the first vma we see as the base */
675 section
->vma
= dst_offset
;
679 dst_offset
-= section
->vma
;
681 dst_base_ptr
= oasys_per_section (section
)->data
;
682 dst_ptr
= oasys_per_section (section
)->data
+
687 section
->flags
|= SEC_LOAD
| SEC_HAS_CONTENTS
;
689 while (src
< end_src
)
691 unsigned char mod_byte
= *src
++;
692 size_t gap
= end_src
- src
;
695 if (mod_byte
== 0 && gap
>= 8)
710 for (relbit
= 1; count
-- != 0 && src
< end_src
; relbit
<<= 1)
712 if (relbit
& mod_byte
)
714 unsigned char reloc
= *src
;
715 /* This item needs to be relocated */
716 switch (reloc
& RELOCATION_TYPE_BITS
)
718 case RELOCATION_TYPE_ABS
:
722 case RELOCATION_TYPE_REL
:
724 /* Relocate the item relative to the section */
727 amt
= sizeof (oasys_reloc_type
);
728 r
= (oasys_reloc_type
*) bfd_alloc (abfd
,
732 *(per
->reloc_tail_ptr
) = r
;
733 per
->reloc_tail_ptr
= &r
->next
;
734 r
->next
= (oasys_reloc_type
*) NULL
;
735 /* Reference to undefined symbol */
737 /* There is no symbol */
739 /* Work out the howto */
743 data
->sections
[reloc
&
744 RELOCATION_SECT_BITS
];
747 r
->relent
.section
->vma
;
749 r
->relent
.address
= dst_ptr
- dst_base_ptr
;
750 r
->relent
.howto
= &howto_table
[reloc
>> 6];
751 r
->relent
.sym_ptr_ptr
= (asymbol
**) NULL
;
752 section
->reloc_count
++;
754 /* Fake up the data to look like
755 it's got the -ve pc in it, this
756 makes it much easier to convert
757 into other formats. This is done
758 by hitting the addend. */
759 if (r
->relent
.howto
->pc_relative
)
760 r
->relent
.addend
-= dst_ptr
- dst_base_ptr
;
765 case RELOCATION_TYPE_UND
:
769 amt
= sizeof (oasys_reloc_type
);
770 r
= (oasys_reloc_type
*) bfd_alloc (abfd
,
774 *(per
->reloc_tail_ptr
) = r
;
775 per
->reloc_tail_ptr
= &r
->next
;
776 r
->next
= (oasys_reloc_type
*) NULL
;
777 /* Reference to undefined symbol */
779 /* Get symbol number */
780 r
->symbol
= (src
[0] << 8) | src
[1];
781 /* Work out the howto */
785 r
->relent
.section
= (asection
788 r
->relent
.addend
= 0;
789 r
->relent
.address
= dst_ptr
- dst_base_ptr
;
790 r
->relent
.howto
= &howto_table
[reloc
>> 6];
791 r
->relent
.sym_ptr_ptr
= (asymbol
**) NULL
;
792 section
->reloc_count
++;
795 /* Fake up the data to look like
796 it's got the -ve pc in it, this
797 makes it much easier to convert
798 into other formats. This is done
799 by hitting the addend. */
800 if (r
->relent
.howto
->pc_relative
)
801 r
->relent
.addend
-= dst_ptr
- dst_base_ptr
;
804 case RELOCATION_TYPE_COM
:
814 case oasys_record_is_local_enum
:
815 case oasys_record_is_symbol_enum
:
816 case oasys_record_is_section_enum
:
828 oasys_new_section_hook (abfd
, newsect
)
832 newsect
->used_by_bfd
= (PTR
)
833 bfd_alloc (abfd
, (bfd_size_type
) sizeof (oasys_per_section_type
));
834 if (!newsect
->used_by_bfd
)
836 oasys_per_section (newsect
)->data
= (bfd_byte
*) NULL
;
837 oasys_per_section (newsect
)->section
= newsect
;
838 oasys_per_section (newsect
)->offset
= 0;
839 oasys_per_section (newsect
)->initialized
= FALSE
;
840 newsect
->alignment_power
= 1;
841 /* Turn the section string into an index */
843 sscanf (newsect
->name
, "%u", &newsect
->target_index
);
850 oasys_get_reloc_upper_bound (abfd
, asect
)
854 if (! oasys_slurp_section_data (abfd
))
856 return (asect
->reloc_count
+ 1) * sizeof (arelent
*);
860 oasys_get_section_contents (abfd
, section
, location
, offset
, count
)
867 oasys_per_section_type
*p
= oasys_per_section (section
);
868 oasys_slurp_section_data (abfd
);
869 if (! p
->initialized
)
871 (void) memset (location
, 0, (size_t) count
);
875 (void) memcpy (location
, (PTR
) (p
->data
+ offset
), (size_t) count
);
882 oasys_canonicalize_reloc (ignore_abfd
, section
, relptr
, symbols
)
883 bfd
*ignore_abfd ATTRIBUTE_UNUSED
;
886 asymbol
**symbols ATTRIBUTE_UNUSED
;
888 unsigned int reloc_count
= 0;
889 oasys_reloc_type
*src
= (oasys_reloc_type
*) (section
->relocation
);
890 while (src
!= (oasys_reloc_type
*) NULL
)
895 if (src
->relent
.section
== (asection
*) NULL
)
897 src
->relent
.sym_ptr_ptr
= symbols
+ src
->symbol
;
901 *relptr
++ = &src
->relent
;
905 *relptr
= (arelent
*) NULL
;
906 return section
->reloc_count
= reloc_count
;
915 /* Calculate the checksum and write one record */
917 oasys_write_record (abfd
, type
, record
, size
)
919 oasys_record_enum_type type
;
920 oasys_record_union_type
*record
;
927 record
->header
.length
= size
;
928 record
->header
.type
= (int) type
;
929 record
->header
.check_sum
= 0;
930 record
->header
.fill
= 0;
931 ptr
= (unsigned char *) &record
->pad
[0];
933 for (i
= 0; i
< size
; i
++)
937 record
->header
.check_sum
= 0xff & (-checksum
);
938 if (bfd_bwrite ((PTR
) record
, (bfd_size_type
) size
, abfd
) != size
)
944 /* Write out all the symbols */
946 oasys_write_syms (abfd
)
950 asymbol
**generic
= bfd_get_outsymbols (abfd
);
951 unsigned int index
= 0;
952 for (count
= 0; count
< bfd_get_symcount (abfd
); count
++)
955 oasys_symbol_record_type symbol
;
956 asymbol
*const g
= generic
[count
];
958 const char *src
= g
->name
;
959 char *dst
= symbol
.name
;
962 if (bfd_is_com_section (g
->section
))
964 symbol
.relb
= RELOCATION_TYPE_COM
;
965 H_PUT_16 (abfd
, index
, symbol
.refno
);
968 else if (bfd_is_abs_section (g
->section
))
970 symbol
.relb
= RELOCATION_TYPE_ABS
;
971 H_PUT_16 (abfd
, 0, symbol
.refno
);
974 else if (bfd_is_und_section (g
->section
))
976 symbol
.relb
= RELOCATION_TYPE_UND
;
977 H_PUT_16 (abfd
, index
, symbol
.refno
);
978 /* Overload the value field with the output index number */
981 else if (g
->flags
& BSF_DEBUGGING
)
988 if (g
->section
== (asection
*) NULL
)
990 /* Sometime, the oasys tools give out a symbol with illegal
991 bits in it, we'll output it in the same broken way */
993 symbol
.relb
= RELOCATION_TYPE_REL
| 0;
997 symbol
.relb
= RELOCATION_TYPE_REL
| g
->section
->output_section
->target_index
;
999 H_PUT_16 (abfd
, 0, symbol
.refno
);
1001 #ifdef UNDERSCORE_HACK
1011 H_PUT_32 (abfd
, g
->value
, symbol
.value
);
1014 if (g
->flags
& BSF_LOCAL
)
1016 if (! oasys_write_record (abfd
,
1017 oasys_record_is_local_enum
,
1018 (oasys_record_union_type
*) & symbol
,
1019 offsetof (oasys_symbol_record_type
,
1025 if (! oasys_write_record (abfd
,
1026 oasys_record_is_symbol_enum
,
1027 (oasys_record_union_type
*) & symbol
,
1028 offsetof (oasys_symbol_record_type
,
1032 g
->value
= index
- 1;
1039 /* Write a section header for each section */
1041 oasys_write_sections (abfd
)
1045 static oasys_section_record_type out
;
1047 for (s
= abfd
->sections
; s
!= (asection
*) NULL
; s
= s
->next
)
1049 if (!ISDIGIT (s
->name
[0]))
1051 (*_bfd_error_handler
)
1052 (_("%s: can not represent section `%s' in oasys"),
1053 bfd_get_filename (abfd
), s
->name
);
1054 bfd_set_error (bfd_error_nonrepresentable_section
);
1057 out
.relb
= RELOCATION_TYPE_REL
| s
->target_index
;
1058 H_PUT_32 (abfd
, s
->_cooked_size
, out
.value
);
1059 H_PUT_32 (abfd
, s
->vma
, out
.vma
);
1061 if (! oasys_write_record (abfd
,
1062 oasys_record_is_section_enum
,
1063 (oasys_record_union_type
*) & out
,
1071 oasys_write_header (abfd
)
1074 /* Create and write the header */
1075 oasys_header_record_type r
;
1076 size_t length
= strlen (abfd
->filename
);
1077 if (length
> (size_t) sizeof (r
.module_name
))
1079 length
= sizeof (r
.module_name
);
1082 (void) memcpy (r
.module_name
,
1085 (void) memset (r
.module_name
+ length
,
1087 sizeof (r
.module_name
) - length
);
1089 r
.version_number
= OASYS_VERSION_NUMBER
;
1090 r
.rev_number
= OASYS_REV_NUMBER
;
1091 if (! oasys_write_record (abfd
,
1092 oasys_record_is_header_enum
,
1093 (oasys_record_union_type
*) & r
,
1094 offsetof (oasys_header_record_type
,
1102 oasys_write_end (abfd
)
1105 oasys_end_record_type end
;
1106 unsigned char null
= 0;
1107 end
.relb
= RELOCATION_TYPE_ABS
;
1108 H_PUT_32 (abfd
, abfd
->start_address
, end
.entry
);
1109 H_PUT_16 (abfd
, 0, end
.fill
);
1111 if (! oasys_write_record (abfd
,
1112 oasys_record_is_end_enum
,
1113 (oasys_record_union_type
*) & end
,
1116 if (bfd_bwrite ((PTR
) &null
, (bfd_size_type
) 1, abfd
) != 1)
1126 arelent
*a
= *((arelent
**) ap
);
1127 arelent
*b
= *((arelent
**) bp
);
1128 return a
->address
- b
->address
;
1136 oasys_write_data (abfd
)
1140 for (s
= abfd
->sections
; s
!= (asection
*) NULL
; s
= s
->next
)
1142 if (s
->flags
& SEC_LOAD
)
1144 bfd_byte
*raw_data
= oasys_per_section (s
)->data
;
1145 oasys_data_record_type processed_data
;
1146 bfd_size_type current_byte_index
= 0;
1147 unsigned int relocs_to_go
= s
->reloc_count
;
1148 arelent
**p
= s
->orelocation
;
1149 if (s
->reloc_count
!= 0)
1151 /* Sort the reloc records so it's easy to insert the relocs into the
1154 qsort (s
->orelocation
,
1156 sizeof (arelent
**),
1159 current_byte_index
= 0;
1160 processed_data
.relb
= s
->target_index
| RELOCATION_TYPE_REL
;
1162 while (current_byte_index
< s
->_cooked_size
)
1164 /* Scan forwards by eight bytes or however much is left and see if
1165 there are any relocations going on */
1166 bfd_byte
*mod
= &processed_data
.data
[0];
1167 bfd_byte
*dst
= &processed_data
.data
[1];
1173 H_PUT_32 (abfd
, s
->vma
+ current_byte_index
,
1174 processed_data
.addr
);
1176 /* Don't start a relocation unless you're sure you can finish it
1177 within the same data record. The worst case relocation is a
1178 4-byte relocatable value which is split across two modification
1179 bytes (1 relocation byte + 2 symbol reference bytes + 2 data +
1180 1 modification byte + 2 data = 8 bytes total). That's where
1181 the magic number 8 comes from.
1183 while (current_byte_index
< s
->_raw_size
&& dst
<=
1184 &processed_data
.data
[sizeof (processed_data
.data
) - 8])
1188 if (relocs_to_go
!= 0)
1191 reloc_howto_type
*const how
= r
->howto
;
1192 /* There is a relocation, is it for this byte ? */
1193 if (r
->address
== current_byte_index
)
1195 unsigned char rel_byte
;
1201 if (how
->pc_relative
)
1203 rel_byte
= RELOCATION_PCREL_BIT
;
1205 /* Also patch the raw data so that it doesn't have
1206 the -ve stuff any more */
1210 bfd_get_16 (abfd
, raw_data
) +
1211 current_byte_index
, raw_data
);
1217 bfd_get_32 (abfd
, raw_data
) +
1218 current_byte_index
, raw_data
);
1227 rel_byte
|= RELOCATION_32BIT_BIT
;
1230 /* Is this a section relative relocation, or a symbol
1231 relative relocation ? */
1235 if (r
->section
!= (asection
*) NULL
)
1237 /* The relent has a section attached, so it must be section
1239 rel_byte
|= RELOCATION_TYPE_REL
;
1240 rel_byte
|= r
->section
->output_section
->target_index
;
1246 asymbol
*sym
= *(r
->sym_ptr_ptr
);
1248 /* If this symbol has a section attached, then it
1249 has already been resolved. Change from a symbol
1250 ref to a section ref */
1251 if (sym
->section
!= (asection
*) NULL
)
1253 rel_byte
|= RELOCATION_TYPE_REL
;
1255 sym
->section
->output_section
->target_index
;
1260 rel_byte
|= RELOCATION_TYPE_UND
;
1262 /* Next two bytes are a symbol index - we can get
1263 this from the symbol value which has been zapped
1264 into the symbol index in the table when the
1265 symbol table was written
1267 *dst
++ = sym
->value
>> 8;
1268 *dst
++ = sym
->value
;
1271 #define ADVANCE { if (++i >= 8) { i = 0; mod = dst++; *mod = 0; } current_byte_index++; }
1272 /* relocations never occur from an unloadable section,
1273 so we can assume that raw_data is not NULL
1275 *dst
++ = *raw_data
++;
1277 * dst
++ = *raw_data
++;
1281 *dst
++ = *raw_data
++;
1283 * dst
++ = *raw_data
++;
1289 /* If this is coming from an unloadable section then copy
1291 if (raw_data
== NULL
)
1297 *dst
++ = *raw_data
++;
1302 /* Don't write a useless null modification byte */
1308 if (! (oasys_write_record
1309 (abfd
, oasys_record_is_data_enum
,
1310 ((oasys_record_union_type
*) &processed_data
),
1311 (size_t) (dst
- (bfd_byte
*) &processed_data
))))
1321 oasys_write_object_contents (abfd
)
1324 if (! oasys_write_header (abfd
))
1326 if (! oasys_write_syms (abfd
))
1328 if (! oasys_write_sections (abfd
))
1330 if (! oasys_write_data (abfd
))
1332 if (! oasys_write_end (abfd
))
1340 /** exec and core file sections */
1342 /* set section contents is complicated with OASYS since the format is
1343 * not a byte image, but a record stream.
1346 oasys_set_section_contents (abfd
, section
, location
, offset
, count
)
1351 bfd_size_type count
;
1355 if (oasys_per_section (section
)->data
== (bfd_byte
*) NULL
)
1357 oasys_per_section (section
)->data
=
1358 (bfd_byte
*) (bfd_alloc (abfd
, section
->_cooked_size
));
1359 if (!oasys_per_section (section
)->data
)
1362 (void) memcpy ((PTR
) (oasys_per_section (section
)->data
+ offset
),
1371 /* Native-level interface to symbols. */
1373 /* We read the symbols into a buffer, which is discarded when this
1374 function exits. We read the strings into a buffer large enough to
1375 hold them all plus all the cached symbol entries. */
1378 oasys_make_empty_symbol (abfd
)
1381 bfd_size_type amt
= sizeof (oasys_symbol_type
);
1382 oasys_symbol_type
*new = (oasys_symbol_type
*) bfd_zalloc (abfd
, amt
);
1385 new->symbol
.the_bfd
= abfd
;
1386 return &new->symbol
;
1392 /* User should have checked the file flags; perhaps we should return
1393 BFD_NO_MORE_SYMBOLS if there are none? */
1396 oasys_openr_next_archived_file (arch
, prev
)
1400 oasys_ar_data_type
*ar
= OASYS_AR_DATA (arch
);
1401 oasys_module_info_type
*p
;
1402 /* take the next one from the arch state, or reset */
1403 if (prev
== (bfd
*) NULL
)
1405 /* Reset the index - the first two entries are bogus*/
1406 ar
->module_index
= 0;
1409 p
= ar
->module
+ ar
->module_index
;
1412 if (ar
->module_index
<= ar
->module_count
)
1414 if (p
->abfd
== (bfd
*) NULL
)
1416 p
->abfd
= _bfd_create_empty_archive_element_shell (arch
);
1417 p
->abfd
->origin
= p
->pos
;
1418 p
->abfd
->filename
= p
->name
;
1420 /* Fixup a pointer to this element for the member */
1421 p
->abfd
->arelt_data
= (PTR
) p
;
1427 bfd_set_error (bfd_error_no_more_archived_files
);
1428 return (bfd
*) NULL
;
1433 oasys_find_nearest_line (abfd
, section
, symbols
, offset
,
1434 filename_ptr
, functionname_ptr
, line_ptr
)
1435 bfd
*abfd ATTRIBUTE_UNUSED
;
1436 asection
*section ATTRIBUTE_UNUSED
;
1437 asymbol
**symbols ATTRIBUTE_UNUSED
;
1438 bfd_vma offset ATTRIBUTE_UNUSED
;
1439 const char **filename_ptr ATTRIBUTE_UNUSED
;
1440 const char **functionname_ptr ATTRIBUTE_UNUSED
;
1441 unsigned int *line_ptr ATTRIBUTE_UNUSED
;
1448 oasys_generic_stat_arch_elt (abfd
, buf
)
1452 oasys_module_info_type
*mod
= (oasys_module_info_type
*) abfd
->arelt_data
;
1453 if (mod
== (oasys_module_info_type
*) NULL
)
1455 bfd_set_error (bfd_error_invalid_operation
);
1460 buf
->st_size
= mod
->size
;
1461 buf
->st_mode
= 0666;
1467 oasys_sizeof_headers (abfd
, exec
)
1468 bfd
*abfd ATTRIBUTE_UNUSED
;
1469 bfd_boolean exec ATTRIBUTE_UNUSED
;
1474 #define oasys_close_and_cleanup _bfd_generic_close_and_cleanup
1475 #define oasys_bfd_free_cached_info _bfd_generic_bfd_free_cached_info
1477 #define oasys_slurp_armap bfd_true
1478 #define oasys_slurp_extended_name_table bfd_true
1479 #define oasys_construct_extended_name_table \
1480 ((bfd_boolean (*) PARAMS ((bfd *, char **, bfd_size_type *, const char **))) \
1482 #define oasys_truncate_arname bfd_dont_truncate_arname
1483 #define oasys_write_armap \
1485 PARAMS ((bfd *, unsigned int, struct orl *, unsigned int, int))) \
1487 #define oasys_read_ar_hdr bfd_nullvoidptr
1488 #define oasys_get_elt_at_index _bfd_generic_get_elt_at_index
1489 #define oasys_update_armap_timestamp bfd_true
1491 #define oasys_bfd_is_local_label_name bfd_generic_is_local_label_name
1492 #define oasys_get_lineno _bfd_nosymbols_get_lineno
1493 #define oasys_bfd_make_debug_symbol _bfd_nosymbols_bfd_make_debug_symbol
1494 #define oasys_read_minisymbols _bfd_generic_read_minisymbols
1495 #define oasys_minisymbol_to_symbol _bfd_generic_minisymbol_to_symbol
1497 #define oasys_bfd_reloc_type_lookup _bfd_norelocs_bfd_reloc_type_lookup
1499 #define oasys_set_arch_mach bfd_default_set_arch_mach
1501 #define oasys_get_section_contents_in_window \
1502 _bfd_generic_get_section_contents_in_window
1504 #define oasys_bfd_get_relocated_section_contents \
1505 bfd_generic_get_relocated_section_contents
1506 #define oasys_bfd_relax_section bfd_generic_relax_section
1507 #define oasys_bfd_gc_sections bfd_generic_gc_sections
1508 #define oasys_bfd_merge_sections bfd_generic_merge_sections
1509 #define oasys_bfd_discard_group bfd_generic_discard_group
1510 #define oasys_bfd_link_hash_table_create _bfd_generic_link_hash_table_create
1511 #define oasys_bfd_link_hash_table_free _bfd_generic_link_hash_table_free
1512 #define oasys_bfd_link_add_symbols _bfd_generic_link_add_symbols
1513 #define oasys_bfd_link_just_syms _bfd_generic_link_just_syms
1514 #define oasys_bfd_final_link _bfd_generic_final_link
1515 #define oasys_bfd_link_split_section _bfd_generic_link_split_section
1518 const bfd_target oasys_vec
=
1521 bfd_target_oasys_flavour
,
1522 BFD_ENDIAN_BIG
, /* target byte order */
1523 BFD_ENDIAN_BIG
, /* target headers byte order */
1524 (HAS_RELOC
| EXEC_P
| /* object flags */
1525 HAS_LINENO
| HAS_DEBUG
|
1526 HAS_SYMS
| HAS_LOCALS
| WP_TEXT
| D_PAGED
),
1527 (SEC_CODE
| SEC_DATA
| SEC_ROM
| SEC_HAS_CONTENTS
1528 | SEC_ALLOC
| SEC_LOAD
| SEC_RELOC
), /* section flags */
1529 0, /* leading underscore */
1530 ' ', /* ar_pad_char */
1531 16, /* ar_max_namelen */
1532 bfd_getb64
, bfd_getb_signed_64
, bfd_putb64
,
1533 bfd_getb32
, bfd_getb_signed_32
, bfd_putb32
,
1534 bfd_getb16
, bfd_getb_signed_16
, bfd_putb16
, /* data */
1535 bfd_getb64
, bfd_getb_signed_64
, bfd_putb64
,
1536 bfd_getb32
, bfd_getb_signed_32
, bfd_putb32
,
1537 bfd_getb16
, bfd_getb_signed_16
, bfd_putb16
, /* hdrs */
1540 oasys_object_p
, /* bfd_check_format */
1544 { /* bfd_set_format */
1547 _bfd_generic_mkarchive
,
1550 { /* bfd_write_contents */
1552 oasys_write_object_contents
,
1553 _bfd_write_archive_contents
,
1557 BFD_JUMP_TABLE_GENERIC (oasys
),
1558 BFD_JUMP_TABLE_COPY (_bfd_generic
),
1559 BFD_JUMP_TABLE_CORE (_bfd_nocore
),
1560 BFD_JUMP_TABLE_ARCHIVE (oasys
),
1561 BFD_JUMP_TABLE_SYMBOLS (oasys
),
1562 BFD_JUMP_TABLE_RELOCS (oasys
),
1563 BFD_JUMP_TABLE_WRITE (oasys
),
1564 BFD_JUMP_TABLE_LINK (oasys
),
1565 BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic
),