1 /* M16C/M32C specific support for 32-bit ELF.
2 Copyright (C) 2005, 2006, 2007
3 Free Software Foundation, Inc.
5 This file is part of BFD, the Binary File Descriptor library.
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.
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.
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. */
26 #include "libiberty.h"
28 /* Forward declarations. */
29 static reloc_howto_type
* m32c_reloc_type_lookup
30 (bfd
*, bfd_reloc_code_real_type
);
31 static void m32c_info_to_howto_rela
32 (bfd
*, arelent
*, Elf_Internal_Rela
*);
33 static bfd_boolean m32c_elf_relocate_section
34 (bfd
*, struct bfd_link_info
*, bfd
*, asection
*, bfd_byte
*, Elf_Internal_Rela
*, Elf_Internal_Sym
*, asection
**);
35 static bfd_boolean m32c_elf_check_relocs
36 (bfd
*, struct bfd_link_info
*, asection
*, const Elf_Internal_Rela
*);
37 static bfd_boolean
m32c_elf_relax_delete_bytes (bfd
*, asection
*, bfd_vma
, int);
39 char * m32c_get_reloc (long reloc
);
40 void dump_symtab (bfd
*, void *, void *);
42 static bfd_boolean m32c_elf_relax_section
43 (bfd
*abfd
, asection
*sec
, struct bfd_link_info
*link_info
, bfd_boolean
*again
);
46 static reloc_howto_type m32c_elf_howto_table
[] =
48 /* This reloc does nothing. */
49 HOWTO (R_M32C_NONE
, /* type */
51 0, /* size (0 = byte, 1 = short, 2 = long) */
53 FALSE
, /* pc_relative */
55 complain_overflow_bitfield
, /* complain_on_overflow */
56 bfd_elf_generic_reloc
, /* special_function */
57 "R_M32C_NONE", /* name */
58 FALSE
, /* partial_inplace */
61 FALSE
), /* pcrel_offset */
63 /* GCC intentionally overflows these next two in order to work
64 around limitations in the addressing modes, so don't complain
66 HOWTO (R_M32C_16
, /* type */
68 1, /* size (0 = byte, 1 = short, 2 = long) */
70 FALSE
, /* pc_relative */
72 complain_overflow_dont
, /* complain_on_overflow */
73 bfd_elf_generic_reloc
, /* special_function */
74 "R_M32C_16", /* name */
75 FALSE
, /* partial_inplace */
77 0xffff, /* dst_mask */
78 FALSE
), /* pcrel_offset */
80 HOWTO (R_M32C_24
, /* type */
82 2, /* size (0 = byte, 1 = short, 2 = long) */
84 FALSE
, /* pc_relative */
86 complain_overflow_dont
, /* complain_on_overflow */
87 bfd_elf_generic_reloc
, /* special_function */
88 "R_M32C_24", /* name */
89 FALSE
, /* partial_inplace */
91 0xffffff, /* dst_mask */
92 FALSE
), /* pcrel_offset */
94 HOWTO (R_M32C_32
, /* type */
96 2, /* size (0 = byte, 1 = short, 2 = long) */
98 FALSE
, /* pc_relative */
100 complain_overflow_bitfield
, /* complain_on_overflow */
101 bfd_elf_generic_reloc
, /* special_function */
102 "R_M32C_32", /* name */
103 FALSE
, /* partial_inplace */
105 0xffffffff, /* dst_mask */
106 FALSE
), /* pcrel_offset */
108 HOWTO (R_M32C_8_PCREL
, /* type */
110 0, /* size (0 = byte, 1 = short, 2 = long) */
112 TRUE
, /* pc_relative */
114 complain_overflow_signed
, /* complain_on_overflow */
115 bfd_elf_generic_reloc
, /* special_function */
116 "R_M32C_8_PCREL", /* name */
117 FALSE
, /* partial_inplace */
120 TRUE
), /* pcrel_offset */
122 HOWTO (R_M32C_16_PCREL
, /* type */
124 1, /* size (0 = byte, 1 = short, 2 = long) */
126 TRUE
, /* pc_relative */
128 complain_overflow_signed
, /* complain_on_overflow */
129 bfd_elf_generic_reloc
, /* special_function */
130 "R_M32C_16_PCREL", /* name */
131 FALSE
, /* partial_inplace */
133 0xffff, /* dst_mask */
134 TRUE
), /* pcrel_offset */
136 HOWTO (R_M32C_8
, /* type */
138 0, /* size (0 = byte, 1 = short, 2 = long) */
140 FALSE
, /* pc_relative */
142 complain_overflow_unsigned
, /* complain_on_overflow */
143 bfd_elf_generic_reloc
, /* special_function */
144 "R_M32C_8", /* name */
145 FALSE
, /* partial_inplace */
148 FALSE
), /* pcrel_offset */
150 HOWTO (R_M32C_LO16
, /* type */
152 1, /* size (0 = byte, 1 = short, 2 = long) */
154 FALSE
, /* pc_relative */
156 complain_overflow_dont
, /* complain_on_overflow */
157 bfd_elf_generic_reloc
, /* special_function */
158 "R_M32C_LO16", /* name */
159 FALSE
, /* partial_inplace */
161 0xffff, /* dst_mask */
162 FALSE
), /* pcrel_offset */
164 HOWTO (R_M32C_HI8
, /* type */
166 0, /* size (0 = byte, 1 = short, 2 = long) */
168 FALSE
, /* pc_relative */
170 complain_overflow_dont
, /* complain_on_overflow */
171 bfd_elf_generic_reloc
, /* special_function */
172 "R_M32C_HI8", /* name */
173 FALSE
, /* partial_inplace */
176 FALSE
), /* pcrel_offset */
178 HOWTO (R_M32C_HI16
, /* type */
180 1, /* size (0 = byte, 1 = short, 2 = long) */
182 FALSE
, /* pc_relative */
184 complain_overflow_dont
, /* complain_on_overflow */
185 bfd_elf_generic_reloc
, /* special_function */
186 "R_M32C_HI16", /* name */
187 FALSE
, /* partial_inplace */
189 0xffff, /* dst_mask */
190 FALSE
), /* pcrel_offset */
192 HOWTO (R_M32C_RL_JUMP
, /* type */
194 0, /* size (0 = byte, 1 = short, 2 = long) */
196 FALSE
, /* pc_relative */
198 complain_overflow_signed
, /* complain_on_overflow */
199 bfd_elf_generic_reloc
, /* special_function */
200 "R_M32C_RL_JUMP", /* name */
201 FALSE
, /* partial_inplace */
204 FALSE
), /* pcrel_offset */
206 HOWTO (R_M32C_RL_1ADDR
, /* type */
208 0, /* size (0 = byte, 1 = short, 2 = long) */
210 FALSE
, /* pc_relative */
212 complain_overflow_signed
, /* complain_on_overflow */
213 bfd_elf_generic_reloc
, /* special_function */
214 "R_M32C_RL_1ADDR", /* name */
215 FALSE
, /* partial_inplace */
218 FALSE
), /* pcrel_offset */
220 HOWTO (R_M32C_RL_2ADDR
, /* type */
222 0, /* size (0 = byte, 1 = short, 2 = long) */
224 FALSE
, /* pc_relative */
226 complain_overflow_signed
, /* complain_on_overflow */
227 bfd_elf_generic_reloc
, /* special_function */
228 "R_M32C_RL_2ADDR", /* name */
229 FALSE
, /* partial_inplace */
232 FALSE
), /* pcrel_offset */
236 /* Map BFD reloc types to M32C ELF reloc types. */
238 struct m32c_reloc_map
240 bfd_reloc_code_real_type bfd_reloc_val
;
241 unsigned int m32c_reloc_val
;
244 static const struct m32c_reloc_map m32c_reloc_map
[] =
246 { BFD_RELOC_NONE
, R_M32C_NONE
},
247 { BFD_RELOC_16
, R_M32C_16
},
248 { BFD_RELOC_24
, R_M32C_24
},
249 { BFD_RELOC_32
, R_M32C_32
},
250 { BFD_RELOC_8_PCREL
, R_M32C_8_PCREL
},
251 { BFD_RELOC_16_PCREL
, R_M32C_16_PCREL
},
252 { BFD_RELOC_8
, R_M32C_8
},
253 { BFD_RELOC_LO16
, R_M32C_LO16
},
254 { BFD_RELOC_HI16
, R_M32C_HI16
},
255 { BFD_RELOC_M32C_HI8
, R_M32C_HI8
},
256 { BFD_RELOC_M32C_RL_JUMP
, R_M32C_RL_JUMP
},
257 { BFD_RELOC_M32C_RL_1ADDR
, R_M32C_RL_1ADDR
},
258 { BFD_RELOC_M32C_RL_2ADDR
, R_M32C_RL_2ADDR
}
261 static reloc_howto_type
*
262 m32c_reloc_type_lookup
263 (bfd
* abfd ATTRIBUTE_UNUSED
,
264 bfd_reloc_code_real_type code
)
268 for (i
= ARRAY_SIZE (m32c_reloc_map
); --i
;)
269 if (m32c_reloc_map
[i
].bfd_reloc_val
== code
)
270 return & m32c_elf_howto_table
[m32c_reloc_map
[i
].m32c_reloc_val
];
275 static reloc_howto_type
*
276 m32c_reloc_name_lookup (bfd
*abfd ATTRIBUTE_UNUSED
, const char *r_name
)
281 i
< sizeof (m32c_elf_howto_table
) / sizeof (m32c_elf_howto_table
[0]);
283 if (m32c_elf_howto_table
[i
].name
!= NULL
284 && strcasecmp (m32c_elf_howto_table
[i
].name
, r_name
) == 0)
285 return &m32c_elf_howto_table
[i
];
290 /* Set the howto pointer for an M32C ELF reloc. */
293 m32c_info_to_howto_rela
294 (bfd
* abfd ATTRIBUTE_UNUSED
,
296 Elf_Internal_Rela
* dst
)
300 r_type
= ELF32_R_TYPE (dst
->r_info
);
301 BFD_ASSERT (r_type
< (unsigned int) R_M32C_max
);
302 cache_ptr
->howto
= & m32c_elf_howto_table
[r_type
];
307 /* Relocate an M32C ELF section.
308 There is some attempt to make this function usable for many architectures,
309 both USE_REL and USE_RELA ['twould be nice if such a critter existed],
310 if only to serve as a learning tool.
312 The RELOCATE_SECTION function is called by the new ELF backend linker
313 to handle the relocations for a section.
315 The relocs are always passed as Rela structures; if the section
316 actually uses Rel structures, the r_addend field will always be
319 This function is responsible for adjusting the section contents as
320 necessary, and (if using Rela relocs and generating a relocatable
321 output file) adjusting the reloc addend as necessary.
323 This function does not have to worry about setting the reloc
324 address or the reloc symbol index.
326 LOCAL_SYMS is a pointer to the swapped in local symbols.
328 LOCAL_SECTIONS is an array giving the section in the input file
329 corresponding to the st_shndx field of each local symbol.
331 The global hash table entry for the global symbols can be found
332 via elf_sym_hashes (input_bfd).
334 When generating relocatable output, this function must handle
335 STB_LOCAL/STT_SECTION symbols specially. The output symbol is
336 going to be the section symbol corresponding to the output
337 section, which means that the addend must be adjusted
341 m32c_elf_relocate_section
342 (bfd
* output_bfd ATTRIBUTE_UNUSED
,
343 struct bfd_link_info
* info
,
345 asection
* input_section
,
347 Elf_Internal_Rela
* relocs
,
348 Elf_Internal_Sym
* local_syms
,
349 asection
** local_sections
)
351 Elf_Internal_Shdr
* symtab_hdr
;
352 struct elf_link_hash_entry
** sym_hashes
;
353 Elf_Internal_Rela
* rel
;
354 Elf_Internal_Rela
* relend
;
358 symtab_hdr
= & elf_tdata (input_bfd
)->symtab_hdr
;
359 sym_hashes
= elf_sym_hashes (input_bfd
);
360 relend
= relocs
+ input_section
->reloc_count
;
362 dynobj
= elf_hash_table (info
)->dynobj
;
365 splt
= bfd_get_section_by_name (dynobj
, ".plt");
367 for (rel
= relocs
; rel
< relend
; rel
++)
369 reloc_howto_type
* howto
;
370 unsigned long r_symndx
;
371 Elf_Internal_Sym
* sym
;
373 struct elf_link_hash_entry
* h
;
375 bfd_reloc_status_type r
;
376 const char * name
= NULL
;
379 r_type
= ELF32_R_TYPE (rel
->r_info
);
381 /* These are only used for relaxing; we don't actually relocate
382 anything with them, so skip them. */
383 if (r_type
== R_M32C_RL_JUMP
384 || r_type
== R_M32C_RL_1ADDR
385 || r_type
== R_M32C_RL_2ADDR
)
388 r_symndx
= ELF32_R_SYM (rel
->r_info
);
390 howto
= m32c_elf_howto_table
+ ELF32_R_TYPE (rel
->r_info
);
396 if (r_symndx
< symtab_hdr
->sh_info
)
398 sym
= local_syms
+ r_symndx
;
399 sec
= local_sections
[r_symndx
];
400 relocation
= (sec
->output_section
->vma
404 name
= bfd_elf_string_from_elf_section
405 (input_bfd
, symtab_hdr
->sh_link
, sym
->st_name
);
406 name
= (sym
->st_name
== 0) ? bfd_section_name (input_bfd
, sec
) : name
;
410 h
= sym_hashes
[r_symndx
- symtab_hdr
->sh_info
];
412 while (h
->root
.type
== bfd_link_hash_indirect
413 || h
->root
.type
== bfd_link_hash_warning
)
414 h
= (struct elf_link_hash_entry
*) h
->root
.u
.i
.link
;
416 name
= h
->root
.root
.string
;
418 if (h
->root
.type
== bfd_link_hash_defined
419 || h
->root
.type
== bfd_link_hash_defweak
)
421 sec
= h
->root
.u
.def
.section
;
422 relocation
= (h
->root
.u
.def
.value
423 + sec
->output_section
->vma
424 + sec
->output_offset
);
426 else if (h
->root
.type
== bfd_link_hash_undefweak
)
428 else if (!info
->relocatable
)
430 if (! ((*info
->callbacks
->undefined_symbol
)
431 (info
, h
->root
.root
.string
, input_bfd
,
432 input_section
, rel
->r_offset
, TRUE
)))
437 if (sec
!= NULL
&& elf_discarded_section (sec
))
439 /* For relocs against symbols from removed linkonce sections,
440 or sections discarded by a linker script, we just want the
441 section contents zeroed. Avoid any special processing. */
442 _bfd_clear_contents (howto
, input_bfd
, contents
+ rel
->r_offset
);
448 if (info
->relocatable
)
450 /* This is a relocatable link. We don't have to change
451 anything, unless the reloc is against a section symbol,
452 in which case we have to adjust according to where the
453 section symbol winds up in the output section. */
454 if (sym
!= NULL
&& ELF_ST_TYPE (sym
->st_info
) == STT_SECTION
)
455 rel
->r_addend
+= sec
->output_offset
;
459 switch (ELF32_R_TYPE (rel
->r_info
))
466 plt_offset
= &h
->plt
.offset
;
468 plt_offset
= elf_local_got_offsets (input_bfd
) + r_symndx
;
470 /* printf("%s: rel %x plt %d\n", h ? h->root.root.string : "(none)",
471 relocation, *plt_offset);*/
472 if (relocation
<= 0xffff)
474 /* If the symbol is in range for a 16-bit address, we should
475 have deallocated the plt entry in relax_section. */
476 BFD_ASSERT (*plt_offset
== (bfd_vma
) -1);
480 /* If the symbol is out of range for a 16-bit address,
481 we must have allocated a plt entry. */
482 BFD_ASSERT (*plt_offset
!= (bfd_vma
) -1);
484 /* If this is the first time we've processed this symbol,
485 fill in the plt entry with the correct symbol address. */
486 if ((*plt_offset
& 1) == 0)
490 x
= 0x000000fc; /* jmpf */
491 x
|= (relocation
<< 8) & 0xffffff00;
492 bfd_put_32 (input_bfd
, x
, splt
->contents
+ *plt_offset
);
496 relocation
= (splt
->output_section
->vma
497 + splt
->output_offset
498 + (*plt_offset
& -2));
501 char *newname
= bfd_malloc (strlen(name
)+5);
502 strcpy (newname
, name
);
503 strcat(newname
, ".plt");
504 _bfd_generic_link_add_one_symbol (info
,
507 BSF_FUNCTION
| BSF_WEAK
,
526 printf ("relocate %s at %06lx relocation %06lx addend %ld ",
527 m32c_elf_howto_table
[ELF32_R_TYPE(rel
->r_info
)].name
,
528 rel
->r_offset
+ input_section
->output_section
->vma
+ input_section
->output_offset
,
529 relocation
, rel
->r_addend
);
533 printf (" %02x", contents
[rel
->r_offset
+i
]);
537 r
= _bfd_final_link_relocate (howto
, input_bfd
, input_section
,
538 contents
, rel
->r_offset
, relocation
,
541 if (r
!= bfd_reloc_ok
)
543 const char * msg
= (const char *) NULL
;
547 case bfd_reloc_overflow
:
548 r
= info
->callbacks
->reloc_overflow
549 (info
, (h
? &h
->root
: NULL
), name
, howto
->name
, (bfd_vma
) 0,
550 input_bfd
, input_section
, rel
->r_offset
);
553 case bfd_reloc_undefined
:
554 r
= info
->callbacks
->undefined_symbol
555 (info
, name
, input_bfd
, input_section
, rel
->r_offset
,
559 case bfd_reloc_outofrange
:
560 msg
= _("internal error: out of range error");
563 case bfd_reloc_notsupported
:
564 msg
= _("internal error: unsupported relocation error");
567 case bfd_reloc_dangerous
:
568 msg
= _("internal error: dangerous relocation");
572 msg
= _("internal error: unknown error");
577 r
= info
->callbacks
->warning
578 (info
, msg
, name
, input_bfd
, input_section
, rel
->r_offset
);
588 /* We support 16-bit pointers to code above 64k by generating a thunk
589 below 64k containing a JMP instruction to the final address. */
592 m32c_elf_check_relocs
594 struct bfd_link_info
* info
,
596 const Elf_Internal_Rela
* relocs
)
598 Elf_Internal_Shdr
* symtab_hdr
;
599 struct elf_link_hash_entry
** sym_hashes
;
600 struct elf_link_hash_entry
** sym_hashes_end
;
601 const Elf_Internal_Rela
* rel
;
602 const Elf_Internal_Rela
* rel_end
;
603 bfd_vma
*local_plt_offsets
;
607 if (info
->relocatable
)
610 symtab_hdr
= &elf_tdata (abfd
)->symtab_hdr
;
611 sym_hashes
= elf_sym_hashes (abfd
);
612 local_plt_offsets
= elf_local_got_offsets (abfd
);
614 dynobj
= elf_hash_table(info
)->dynobj
;
616 sym_hashes_end
= sym_hashes
+ symtab_hdr
->sh_size
/sizeof (Elf32_External_Sym
);
617 if (!elf_bad_symtab (abfd
))
618 sym_hashes_end
-= symtab_hdr
->sh_info
;
620 rel_end
= relocs
+ sec
->reloc_count
;
621 for (rel
= relocs
; rel
< rel_end
; rel
++)
623 struct elf_link_hash_entry
*h
;
624 unsigned long r_symndx
;
627 r_symndx
= ELF32_R_SYM (rel
->r_info
);
628 if (r_symndx
< symtab_hdr
->sh_info
)
632 h
= sym_hashes
[r_symndx
- symtab_hdr
->sh_info
];
633 while (h
->root
.type
== bfd_link_hash_indirect
634 || h
->root
.type
== bfd_link_hash_warning
)
635 h
= (struct elf_link_hash_entry
*) h
->root
.u
.i
.link
;
638 switch (ELF32_R_TYPE (rel
->r_info
))
640 /* This relocation describes a 16-bit pointer to a function.
641 We may need to allocate a thunk in low memory; reserve memory
645 elf_hash_table (info
)->dynobj
= dynobj
= abfd
;
648 splt
= bfd_get_section_by_name (dynobj
, ".plt");
651 flagword flags
= (SEC_ALLOC
| SEC_LOAD
| SEC_HAS_CONTENTS
652 | SEC_IN_MEMORY
| SEC_LINKER_CREATED
653 | SEC_READONLY
| SEC_CODE
);
654 splt
= bfd_make_section_with_flags (dynobj
, ".plt", flags
);
656 || ! bfd_set_section_alignment (dynobj
, splt
, 1))
662 offset
= &h
->plt
.offset
;
665 if (local_plt_offsets
== NULL
)
670 size
= symtab_hdr
->sh_info
* sizeof (bfd_vma
);
671 local_plt_offsets
= (bfd_vma
*) bfd_alloc (abfd
, size
);
672 if (local_plt_offsets
== NULL
)
674 elf_local_got_offsets (abfd
) = local_plt_offsets
;
676 for (i
= 0; i
< symtab_hdr
->sh_info
; i
++)
677 local_plt_offsets
[i
] = (bfd_vma
) -1;
679 offset
= &local_plt_offsets
[r_symndx
];
682 if (*offset
== (bfd_vma
) -1)
684 *offset
= splt
->size
;
694 /* This must exist if dynobj is ever set. */
697 m32c_elf_finish_dynamic_sections (bfd
*abfd ATTRIBUTE_UNUSED
,
698 struct bfd_link_info
*info
)
703 /* As an extra sanity check, verify that all plt entries have
706 if ((dynobj
= elf_hash_table (info
)->dynobj
) != NULL
707 && (splt
= bfd_get_section_by_name (dynobj
, ".plt")) != NULL
)
709 bfd_byte
*contents
= splt
->contents
;
710 unsigned int i
, size
= splt
->size
;
711 for (i
= 0; i
< size
; i
+= 4)
713 unsigned int x
= bfd_get_32 (dynobj
, contents
+ i
);
722 m32c_elf_always_size_sections (bfd
*output_bfd ATTRIBUTE_UNUSED
,
723 struct bfd_link_info
*info
)
728 if (info
->relocatable
)
731 dynobj
= elf_hash_table (info
)->dynobj
;
735 splt
= bfd_get_section_by_name (dynobj
, ".plt");
736 BFD_ASSERT (splt
!= NULL
);
738 splt
->contents
= (bfd_byte
*) bfd_zalloc (dynobj
, splt
->size
);
739 if (splt
->contents
== NULL
)
745 /* Function to set the ELF flag bits. */
748 m32c_elf_set_private_flags (bfd
*abfd
, flagword flags
)
750 elf_elfheader (abfd
)->e_flags
= flags
;
751 elf_flags_init (abfd
) = TRUE
;
755 /* Merge backend specific data from an object file to the output
756 object file when linking. */
759 m32c_elf_merge_private_bfd_data (bfd
*ibfd
, bfd
*obfd
)
761 flagword old_flags
, old_partial
;
762 flagword new_flags
, new_partial
;
763 bfd_boolean error
= FALSE
;
767 new_opt
[0] = old_opt
[0] = '\0';
768 new_flags
= elf_elfheader (ibfd
)->e_flags
;
769 old_flags
= elf_elfheader (obfd
)->e_flags
;
772 (*_bfd_error_handler
) ("old_flags = 0x%.8lx, new_flags = 0x%.8lx, init = %s, filename = %s",
773 old_flags
, new_flags
, elf_flags_init (obfd
) ? "yes" : "no",
774 bfd_get_filename (ibfd
));
777 if (!elf_flags_init (obfd
))
779 /* First call, no flags set. */
780 elf_flags_init (obfd
) = TRUE
;
781 elf_elfheader (obfd
)->e_flags
= new_flags
;
784 else if (new_flags
== old_flags
)
785 /* Compatible flags are ok. */
788 else /* Possibly incompatible flags. */
790 /* Warn if different cpu is used (allow a specific cpu to override
792 new_partial
= (new_flags
& EF_M32C_CPU_MASK
);
793 old_partial
= (old_flags
& EF_M32C_CPU_MASK
);
794 if (new_partial
== old_partial
)
801 default: strcat (new_opt
, " -m16c"); break;
802 case EF_M32C_CPU_M16C
: strcat (new_opt
, " -m16c"); break;
803 case EF_M32C_CPU_M32C
: strcat (new_opt
, " -m32c"); break;
808 default: strcat (old_opt
, " -m16c"); break;
809 case EF_M32C_CPU_M16C
: strcat (old_opt
, " -m16c"); break;
810 case EF_M32C_CPU_M32C
: strcat (old_opt
, " -m32c"); break;
814 /* Print out any mismatches from above. */
818 (*_bfd_error_handler
)
819 (_("%s: compiled with %s and linked with modules compiled with %s"),
820 bfd_get_filename (ibfd
), new_opt
, old_opt
);
823 new_flags
&= ~ EF_M32C_ALL_FLAGS
;
824 old_flags
&= ~ EF_M32C_ALL_FLAGS
;
826 /* Warn about any other mismatches. */
827 if (new_flags
!= old_flags
)
830 (*_bfd_error_handler
)
831 (_("%s: uses different e_flags (0x%lx) fields than previous modules (0x%lx)"),
832 bfd_get_filename (ibfd
), (long)new_flags
, (long)old_flags
);
837 bfd_set_error (bfd_error_bad_value
);
844 m32c_elf_print_private_bfd_data (bfd
*abfd
, PTR ptr
)
846 FILE *file
= (FILE *) ptr
;
849 BFD_ASSERT (abfd
!= NULL
&& ptr
!= NULL
);
851 /* Print normal ELF private data. */
852 _bfd_elf_print_private_bfd_data (abfd
, ptr
);
854 flags
= elf_elfheader (abfd
)->e_flags
;
855 fprintf (file
, _("private flags = 0x%lx:"), (long)flags
);
857 switch (flags
& EF_M32C_CPU_MASK
)
860 case EF_M32C_CPU_M16C
: fprintf (file
, " -m16c"); break;
861 case EF_M32C_CPU_M32C
: fprintf (file
, " -m32c"); break;
868 /* Return the MACH for an e_flags value. */
871 elf32_m32c_machine (bfd
*abfd
)
873 switch (elf_elfheader (abfd
)->e_flags
& EF_M32C_CPU_MASK
)
875 case EF_M32C_CPU_M16C
: return bfd_mach_m16c
;
876 case EF_M32C_CPU_M32C
: return bfd_mach_m32c
;
879 return bfd_mach_m16c
;
883 m32c_elf_object_p (bfd
*abfd
)
885 bfd_default_set_arch_mach (abfd
, bfd_arch_m32c
,
886 elf32_m32c_machine (abfd
));
893 dump_symtab (bfd
* abfd
, void *internal_syms
, void *external_syms
)
896 Elf_Internal_Sym
*isymbuf
;
897 Elf_Internal_Sym
*isymend
;
898 Elf_Internal_Sym
*isym
;
899 Elf_Internal_Shdr
*symtab_hdr
;
900 bfd_boolean free_internal
= 0, free_external
= 0;
902 char * st_info_stb_str
;
908 internal_syms
= bfd_malloc (1000);
913 external_syms
= bfd_malloc (1000);
917 symtab_hdr
= &elf_tdata (abfd
)->symtab_hdr
;
918 locsymcount
= symtab_hdr
->sh_size
/ get_elf_backend_data(abfd
)->s
->sizeof_sym
;
920 isymbuf
= bfd_elf_get_elf_syms (abfd
, symtab_hdr
,
921 symtab_hdr
->sh_info
, 0,
922 internal_syms
, external_syms
, NULL
);
924 isymbuf
= internal_syms
;
925 isymend
= isymbuf
+ locsymcount
;
927 for (isym
= isymbuf
; isym
< isymend
; isym
++)
929 switch (ELF_ST_TYPE (isym
->st_info
))
931 case STT_FUNC
: st_info_str
= "STT_FUNC";
932 case STT_SECTION
: st_info_str
= "STT_SECTION";
933 case STT_FILE
: st_info_str
= "STT_FILE";
934 case STT_OBJECT
: st_info_str
= "STT_OBJECT";
935 case STT_TLS
: st_info_str
= "STT_TLS";
936 default: st_info_str
= "";
938 switch (ELF_ST_BIND (isym
->st_info
))
940 case STB_LOCAL
: st_info_stb_str
= "STB_LOCAL";
941 case STB_GLOBAL
: st_info_stb_str
= "STB_GLOBAL";
942 default: st_info_stb_str
= "";
944 switch (ELF_ST_VISIBILITY (isym
->st_other
))
946 case STV_DEFAULT
: st_other_str
= "STV_DEFAULT";
947 case STV_INTERNAL
: st_other_str
= "STV_INTERNAL";
948 case STV_PROTECTED
: st_other_str
= "STV_PROTECTED";
949 default: st_other_str
= "";
951 switch (isym
->st_shndx
)
953 case SHN_ABS
: st_shndx_str
= "SHN_ABS";
954 case SHN_COMMON
: st_shndx_str
= "SHN_COMMON";
955 case SHN_UNDEF
: st_shndx_str
= "SHN_UNDEF";
956 default: st_shndx_str
= "";
959 printf ("isym = %p st_value = %lx st_size = %lx st_name = (%lu) %s "
960 "st_info = (%d) %s %s st_other = (%d) %s st_shndx = (%d) %s\n",
962 (unsigned long) isym
->st_value
,
963 (unsigned long) isym
->st_size
,
965 bfd_elf_string_from_elf_section (abfd
, symtab_hdr
->sh_link
,
967 isym
->st_info
, st_info_str
, st_info_stb_str
,
968 isym
->st_other
, st_other_str
,
969 isym
->st_shndx
, st_shndx_str
);
972 free (internal_syms
);
974 free (external_syms
);
978 m32c_get_reloc (long reloc
)
980 if (0 <= reloc
&& reloc
< R_M32C_max
)
981 return m32c_elf_howto_table
[reloc
].name
;
987 /* Handle relaxing. */
989 /* A subroutine of m32c_elf_relax_section. If the global symbol H
990 is within the low 64k, remove any entry for it in the plt. */
992 struct relax_plt_data
999 m32c_relax_plt_check (struct elf_link_hash_entry
*h
,
1002 struct relax_plt_data
*data
= (struct relax_plt_data
*) xdata
;
1004 if (h
->root
.type
== bfd_link_hash_warning
)
1005 h
= (struct elf_link_hash_entry
*) h
->root
.u
.i
.link
;
1007 if (h
->plt
.offset
!= (bfd_vma
) -1)
1011 if (h
->root
.type
== bfd_link_hash_undefined
1012 || h
->root
.type
== bfd_link_hash_undefweak
)
1015 address
= (h
->root
.u
.def
.section
->output_section
->vma
1016 + h
->root
.u
.def
.section
->output_offset
1017 + h
->root
.u
.def
.value
);
1019 if (address
<= 0xffff)
1022 data
->splt
->size
-= 4;
1023 *data
->again
= TRUE
;
1030 /* A subroutine of m32c_elf_relax_section. If the global symbol H
1031 previously had a plt entry, give it a new entry offset. */
1034 m32c_relax_plt_realloc (struct elf_link_hash_entry
*h
,
1037 bfd_vma
*entry
= (bfd_vma
*) xdata
;
1039 if (h
->root
.type
== bfd_link_hash_warning
)
1040 h
= (struct elf_link_hash_entry
*) h
->root
.u
.i
.link
;
1042 if (h
->plt
.offset
!= (bfd_vma
) -1)
1044 h
->plt
.offset
= *entry
;
1052 m32c_elf_relax_plt_section (bfd
*dynobj
,
1054 struct bfd_link_info
*info
,
1057 struct relax_plt_data relax_plt_data
;
1060 /* Assume nothing changes. */
1063 if (info
->relocatable
)
1066 /* We only relax the .plt section at the moment. */
1067 if (dynobj
!= elf_hash_table (info
)->dynobj
1068 || strcmp (splt
->name
, ".plt") != 0)
1071 /* Quick check for an empty plt. */
1072 if (splt
->size
== 0)
1075 /* Map across all global symbols; see which ones happen to
1076 fall in the low 64k. */
1077 relax_plt_data
.splt
= splt
;
1078 relax_plt_data
.again
= again
;
1079 elf_link_hash_traverse (elf_hash_table (info
), m32c_relax_plt_check
,
1082 /* Likewise for local symbols, though that's somewhat less convenient
1083 as we have to walk the list of input bfds and swap in symbol data. */
1084 for (ibfd
= info
->input_bfds
; ibfd
; ibfd
= ibfd
->link_next
)
1086 bfd_vma
*local_plt_offsets
= elf_local_got_offsets (ibfd
);
1087 Elf_Internal_Shdr
*symtab_hdr
;
1088 Elf_Internal_Sym
*isymbuf
= NULL
;
1091 if (! local_plt_offsets
)
1094 symtab_hdr
= &elf_tdata (ibfd
)->symtab_hdr
;
1095 if (symtab_hdr
->sh_info
!= 0)
1097 isymbuf
= (Elf_Internal_Sym
*) symtab_hdr
->contents
;
1098 if (isymbuf
== NULL
)
1099 isymbuf
= bfd_elf_get_elf_syms (ibfd
, symtab_hdr
,
1100 symtab_hdr
->sh_info
, 0,
1102 if (isymbuf
== NULL
)
1106 for (idx
= 0; idx
< symtab_hdr
->sh_info
; ++idx
)
1108 Elf_Internal_Sym
*isym
;
1112 if (local_plt_offsets
[idx
] == (bfd_vma
) -1)
1115 isym
= &isymbuf
[idx
];
1116 if (isym
->st_shndx
== SHN_UNDEF
)
1118 else if (isym
->st_shndx
== SHN_ABS
)
1119 tsec
= bfd_abs_section_ptr
;
1120 else if (isym
->st_shndx
== SHN_COMMON
)
1121 tsec
= bfd_com_section_ptr
;
1123 tsec
= bfd_section_from_elf_index (ibfd
, isym
->st_shndx
);
1125 address
= (tsec
->output_section
->vma
1126 + tsec
->output_offset
1128 if (address
<= 0xffff)
1130 local_plt_offsets
[idx
] = -1;
1137 && symtab_hdr
->contents
!= (unsigned char *) isymbuf
)
1139 if (! info
->keep_memory
)
1143 /* Cache the symbols for elf_link_input_bfd. */
1144 symtab_hdr
->contents
= (unsigned char *) isymbuf
;
1149 /* If we changed anything, walk the symbols again to reallocate
1150 .plt entry addresses. */
1151 if (*again
&& splt
->size
> 0)
1155 elf_link_hash_traverse (elf_hash_table (info
),
1156 m32c_relax_plt_realloc
, &entry
);
1158 for (ibfd
= info
->input_bfds
; ibfd
; ibfd
= ibfd
->link_next
)
1160 bfd_vma
*local_plt_offsets
= elf_local_got_offsets (ibfd
);
1161 unsigned int nlocals
= elf_tdata (ibfd
)->symtab_hdr
.sh_info
;
1164 if (! local_plt_offsets
)
1167 for (idx
= 0; idx
< nlocals
; ++idx
)
1168 if (local_plt_offsets
[idx
] != (bfd_vma
) -1)
1170 local_plt_offsets
[idx
] = entry
;
1180 compare_reloc (const void *e1
, const void *e2
)
1182 const Elf_Internal_Rela
*i1
= (const Elf_Internal_Rela
*) e1
;
1183 const Elf_Internal_Rela
*i2
= (const Elf_Internal_Rela
*) e2
;
1185 if (i1
->r_offset
== i2
->r_offset
)
1188 return i1
->r_offset
< i2
->r_offset
? -1 : 1;
1191 #define OFFSET_FOR_RELOC(rel) m32c_offset_for_reloc (abfd, rel, symtab_hdr, shndx_buf, intsyms)
1193 m32c_offset_for_reloc (bfd
*abfd
,
1194 Elf_Internal_Rela
*rel
,
1195 Elf_Internal_Shdr
*symtab_hdr
,
1196 Elf_External_Sym_Shndx
*shndx_buf
,
1197 Elf_Internal_Sym
*intsyms
)
1201 /* Get the value of the symbol referred to by the reloc. */
1202 if (ELF32_R_SYM (rel
->r_info
) < symtab_hdr
->sh_info
)
1204 /* A local symbol. */
1205 Elf_Internal_Sym
*isym
;
1206 Elf_External_Sym_Shndx
*shndx
;
1210 isym
= intsyms
+ ELF32_R_SYM (rel
->r_info
);
1211 ssec
= bfd_section_from_elf_index (abfd
, isym
->st_shndx
);
1212 shndx
= shndx_buf
+ (shndx_buf
? ELF32_R_SYM (rel
->r_info
) : 0);
1214 symval
= isym
->st_value
;
1216 symval
+= ssec
->output_section
->vma
1217 + ssec
->output_offset
;
1222 struct elf_link_hash_entry
*h
;
1224 /* An external symbol. */
1225 indx
= ELF32_R_SYM (rel
->r_info
) - symtab_hdr
->sh_info
;
1226 h
= elf_sym_hashes (abfd
)[indx
];
1227 BFD_ASSERT (h
!= NULL
);
1229 if (h
->root
.type
!= bfd_link_hash_defined
1230 && h
->root
.type
!= bfd_link_hash_defweak
)
1231 /* This appears to be a reference to an undefined
1232 symbol. Just ignore it--it will be caught by the
1233 regular reloc processing. */
1236 symval
= (h
->root
.u
.def
.value
1237 + h
->root
.u
.def
.section
->output_section
->vma
1238 + h
->root
.u
.def
.section
->output_offset
);
1243 static int bytes_saved
= 0;
1245 static int bytes_to_reloc
[] = {
1253 /* What we use the bits in a relax reloc addend (R_M32C_RL_*) for. */
1255 /* Mask for the number of relocs associated with this insn. */
1256 #define RLA_RELOCS 0x0000000f
1257 /* Number of bytes gas emitted (before gas's relaxing) */
1258 #define RLA_NBYTES 0x00000ff0
1260 /* If the displacement is within the given range and the new encoding
1261 differs from the old encoding (the index), then the insn can be
1262 relaxed to the new encoding. */
1265 unsigned int max_disp
;
1266 unsigned char new_encoding
;
1269 static EncodingTable m16c_addr_encodings
[] = {
1270 { 0, 0, 0 }, /* R0 */
1271 { 0, 0, 1 }, /* R1 */
1272 { 0, 0, 2 }, /* R2 */
1273 { 0, 0, 3 }, /* R3 */
1274 { 0, 0, 4 }, /* A0 */
1275 { 0, 0, 5 }, /* A1 */
1276 { 0, 0, 6 }, /* [A0] */
1277 { 0, 0, 7 }, /* [A1] */
1278 { 1, 0, 6 }, /* udsp:8[A0] */
1279 { 1, 0, 7 }, /* udsp:8[A1] */
1280 { 1, 0, 10 }, /* udsp:8[SB] */
1281 { 1, 0, 11 }, /* sdsp:8[FB] */
1282 { 2, 255, 8 }, /* udsp:16[A0] */
1283 { 2, 255, 9 }, /* udsp:16[A1] */
1284 { 2, 255, 10 }, /* udsp:16[SB] */
1285 { 2, 0, 15 }, /* abs:16 */
1288 static EncodingTable m16c_jmpaddr_encodings
[] = {
1289 { 0, 0, 0 }, /* R0 */
1290 { 0, 0, 1 }, /* R1 */
1291 { 0, 0, 2 }, /* R2 */
1292 { 0, 0, 3 }, /* R3 */
1293 { 0, 0, 4 }, /* A0 */
1294 { 0, 0, 5 }, /* A1 */
1295 { 0, 0, 6 }, /* [A0] */
1296 { 0, 0, 7 }, /* [A1] */
1297 { 1, 0, 6 }, /* udsp:8[A0] */
1298 { 1, 0, 7 }, /* udsp:8[A1] */
1299 { 1, 0, 10 }, /* udsp:8[SB] */
1300 { 1, 0, 11 }, /* sdsp:8[FB] */
1301 { 3, 255, 8 }, /* udsp:20[A0] */
1302 { 3, 255, 9 }, /* udsp:20[A1] */
1303 { 2, 255, 10 }, /* udsp:16[SB] */
1304 { 2, 0, 15 }, /* abs:16 */
1307 static EncodingTable m32c_addr_encodings
[] = {
1308 { 0, 0, 0 }, /* [A0] */
1309 { 0, 0, 1 }, /* [A1] */
1310 { 0, 0, 2 }, /* A0 */
1311 { 0, 0, 3 }, /* A1 */
1312 { 1, 0, 0 }, /* udsp:8[A0] */
1313 { 1, 0, 1 }, /* udsp:8[A1] */
1314 { 1, 0, 6 }, /* udsp:8[SB] */
1315 { 1, 0, 7 }, /* sdsp:8[FB] */
1316 { 2, 255, 4 }, /* udsp:16[A0] */
1317 { 2, 255, 5 }, /* udsp:16[A1] */
1318 { 2, 255, 6 }, /* udsp:16[SB] */
1319 { 2, 127, 7 }, /* sdsp:16[FB] */
1320 { 3, 65535, 8 }, /* udsp:24[A0] */
1321 { 3, 65535, 9 }, /* udsp:24[A1] */
1322 { 3, 65535, 15 }, /* abs24 */
1323 { 2, 0, 15 }, /* abs16 */
1324 { 0, 0, 16 }, /* R2 */
1325 { 0, 0, 17 }, /* R3 */
1326 { 0, 0, 18 }, /* R0 */
1327 { 0, 0, 19 }, /* R1 */
1343 m32c_elf_relax_section
1346 struct bfd_link_info
* link_info
,
1347 bfd_boolean
* again
)
1349 Elf_Internal_Shdr
*symtab_hdr
;
1350 Elf_Internal_Shdr
*shndx_hdr
;
1351 Elf_Internal_Rela
*internal_relocs
;
1352 Elf_Internal_Rela
*free_relocs
= NULL
;
1353 Elf_Internal_Rela
*irel
, *irelend
, *srel
;
1354 bfd_byte
* contents
= NULL
;
1355 bfd_byte
* free_contents
= NULL
;
1356 Elf_Internal_Sym
*intsyms
= NULL
;
1357 Elf_Internal_Sym
*free_intsyms
= NULL
;
1358 Elf_External_Sym_Shndx
*shndx_buf
= NULL
;
1361 if (abfd
== elf_hash_table (link_info
)->dynobj
1362 && strcmp (sec
->name
, ".plt") == 0)
1363 return m32c_elf_relax_plt_section (abfd
, sec
, link_info
, again
);
1365 /* Assume nothing changes. */
1368 machine
= elf32_m32c_machine (abfd
);
1370 /* We don't have to do anything for a relocatable link, if
1371 this section does not have relocs, or if this is not a
1373 if (link_info
->relocatable
1374 || (sec
->flags
& SEC_RELOC
) == 0
1375 || sec
->reloc_count
== 0
1376 || (sec
->flags
& SEC_CODE
) == 0)
1379 symtab_hdr
= &elf_tdata (abfd
)->symtab_hdr
;
1380 shndx_hdr
= &elf_tdata (abfd
)->symtab_shndx_hdr
;
1382 /* Get the section contents. */
1383 if (elf_section_data (sec
)->this_hdr
.contents
!= NULL
)
1384 contents
= elf_section_data (sec
)->this_hdr
.contents
;
1385 /* Go get them off disk. */
1386 else if (!bfd_malloc_and_get_section (abfd
, sec
, &contents
))
1389 /* Read this BFD's symbols. */
1390 /* Get cached copy if it exists. */
1391 if (symtab_hdr
->contents
!= NULL
)
1393 intsyms
= (Elf_Internal_Sym
*) symtab_hdr
->contents
;
1397 intsyms
= bfd_elf_get_elf_syms (abfd
, symtab_hdr
, symtab_hdr
->sh_info
, 0, NULL
, NULL
, NULL
);
1398 symtab_hdr
->contents
= (bfd_byte
*) intsyms
;
1401 if (shndx_hdr
->sh_size
!= 0)
1405 amt
= symtab_hdr
->sh_info
;
1406 amt
*= sizeof (Elf_External_Sym_Shndx
);
1407 shndx_buf
= (Elf_External_Sym_Shndx
*) bfd_malloc (amt
);
1408 if (shndx_buf
== NULL
)
1410 if (bfd_seek (abfd
, shndx_hdr
->sh_offset
, SEEK_SET
) != 0
1411 || bfd_bread ((PTR
) shndx_buf
, amt
, abfd
) != amt
)
1413 shndx_hdr
->contents
= (bfd_byte
*) shndx_buf
;
1416 /* Get a copy of the native relocations. */
1417 internal_relocs
= (_bfd_elf_link_read_relocs
1418 (abfd
, sec
, (PTR
) NULL
, (Elf_Internal_Rela
*) NULL
,
1419 link_info
->keep_memory
));
1420 if (internal_relocs
== NULL
)
1422 if (! link_info
->keep_memory
)
1423 free_relocs
= internal_relocs
;
1425 /* The RL_ relocs must be just before the operand relocs they go
1426 with, so we must sort them to guarantee this. */
1427 qsort (internal_relocs
, sec
->reloc_count
, sizeof (Elf_Internal_Rela
),
1430 /* Walk through them looking for relaxing opportunities. */
1431 irelend
= internal_relocs
+ sec
->reloc_count
;
1433 for (irel
= internal_relocs
; irel
< irelend
; irel
++)
1436 unsigned char *insn
, *gap
, *einsn
;
1438 bfd_signed_vma pcrel
;
1444 EncodingTable
*enctbl
;
1447 if (ELF32_R_TYPE(irel
->r_info
) != R_M32C_RL_JUMP
1448 && ELF32_R_TYPE(irel
->r_info
) != R_M32C_RL_1ADDR
1449 && ELF32_R_TYPE(irel
->r_info
) != R_M32C_RL_2ADDR
)
1454 /* There will always be room for the relaxed insn, since it is smaller
1455 than the one it would replace. */
1456 BFD_ASSERT (irel
->r_offset
< sec
->size
);
1458 insn
= contents
+ irel
->r_offset
;
1459 relax_relocs
= irel
->r_addend
% 16;
1461 /* Ok, we only have three relocs we care about, and they're all
1462 fake. The lower four bits of the addend is always the number
1463 of following relocs (hence the qsort above) that are assigned
1464 to this opcode. The next 8 bits of the addend indicates the
1465 number of bytes in the insn. We use the rest of them
1466 ourselves as flags for the more expensive operations (defines
1467 above). The three relocs are:
1469 RL_JUMP: This marks all direct jump insns. We check the
1470 displacement and replace them with shorter jumps if
1471 they're in range. We also use this to find JMP.S
1472 insns and manually shorten them when we delete bytes.
1473 We have to decode these insns to figure out what to
1476 RL_1ADDR: This is a :G or :Q insn, which has a single
1477 "standard" operand. We have to extract the type
1478 field, see if it's a wide displacement, then figure
1479 out if we can replace it with a narrow displacement.
1480 We don't have to decode these insns.
1482 RL_2ADDR: Similarly, but two "standard" operands. Note that
1483 r_addend may still be 1, as standard operands don't
1484 always have displacements. Gas shouldn't give us one
1485 with zero operands, but since we don't know which one
1486 has the displacement, we check them both anyway.
1488 These all point to the beginning of the insn itself, not the
1491 Note that we only relax one step at a time, relying on the
1492 linker to call us repeatedly. Thus, there is no code for
1493 JMP.A->JMP.B although that will happen in two steps.
1494 Likewise, for 2ADDR relaxes, we do one operand per cycle.
1497 /* Get the value of the symbol referred to by the reloc. Just
1498 in case this is the last reloc in the list, use the RL's
1499 addend to choose between this reloc (no addend) or the next
1500 (yes addend, which means at least one following reloc). */
1501 srel
= irel
+ (relax_relocs
? 1 : 0);
1502 symval
= OFFSET_FOR_RELOC (srel
);
1504 /* Setting gap_size nonzero is the flag which means "something
1508 new_type
= ELF32_R_TYPE(srel
->r_info
);
1510 pc
= sec
->output_section
->vma
+ sec
->output_offset
1512 pcrel
= symval
- pc
+ srel
->r_addend
;
1514 if (machine
== bfd_mach_m16c
)
1518 switch (ELF32_R_TYPE(irel
->r_info
))
1521 case R_M32C_RL_JUMP
:
1524 case 0xfe: /* jmp.b */
1525 if (pcrel
>= 2 && pcrel
<= 9)
1527 /* Relax JMP.B -> JMP.S. We need to get rid of
1528 the following reloc though. */
1529 insn
[0] = 0x60 | (pcrel
- 2);
1530 new_type
= R_M32C_NONE
;
1531 irel
->r_addend
= 0x10;
1537 case 0xf4: /* jmp.w */
1538 /* 128 is allowed because it will be one byte closer
1539 after relaxing. Likewise for all other pc-rel
1541 if (pcrel
<= 128 && pcrel
>= -128)
1543 /* Relax JMP.W -> JMP.B */
1546 new_type
= R_M32C_8_PCREL
;
1552 case 0xfc: /* jmp.a */
1553 if (pcrel
<= 32768 && pcrel
>= -32768)
1555 /* Relax JMP.A -> JMP.W */
1559 new_type
= R_M32C_16_PCREL
;
1565 case 0xfd: /* jsr.a */
1566 if (pcrel
<= 32768 && pcrel
>= -32768)
1568 /* Relax JSR.A -> JSR.W */
1572 new_type
= R_M32C_16_PCREL
;
1580 case R_M32C_RL_2ADDR
:
1581 /* xxxx xxxx srce dest [src-disp] [dest-disp]*/
1583 enctbl
= m16c_addr_encodings
;
1585 enc
= (insn
[1] >> 4) & 0x0f;
1588 if (srel
->r_offset
== irel
->r_offset
+ posn
1589 && e
->new_encoding
!= enc
1590 && symval
<= e
->max_disp
)
1593 insn
[1] |= e
->new_encoding
<< 4;
1594 gap_size
= e
->bytes
- enctbl
[e
->new_encoding
].bytes
;
1595 gap
= insn
+ posn
+ enctbl
[e
->new_encoding
].bytes
;
1596 new_type
= bytes_to_reloc
[enctbl
[e
->new_encoding
].bytes
];
1599 if (relax_relocs
== 2)
1605 case R_M32C_RL_1ADDR
:
1606 /* xxxx xxxx xxxx dest [disp] */
1608 enctbl
= m16c_addr_encodings
;
1611 /* Check the opcode for jumps. We know it's safe to
1612 do this because all 2ADDR insns are at least two
1614 enc
= insn
[0] * 256 + insn
[1];
1621 enctbl
= m16c_jmpaddr_encodings
;
1625 /* srel, posn, and enc must be set here. */
1627 symval
= OFFSET_FOR_RELOC (srel
);
1628 enc
= insn
[1] & 0x0f;
1631 if (srel
->r_offset
== irel
->r_offset
+ posn
1632 && e
->new_encoding
!= enc
1633 && symval
<= e
->max_disp
)
1636 insn
[1] |= e
->new_encoding
;
1637 gap_size
= e
->bytes
- enctbl
[e
->new_encoding
].bytes
;
1638 gap
= insn
+ posn
+ enctbl
[e
->new_encoding
].bytes
;
1639 new_type
= bytes_to_reloc
[enctbl
[e
->new_encoding
].bytes
];
1645 } /* Ends switch (reloc type) for m16c. */
1647 else /* machine == bfd_mach_m32c */
1651 switch (ELF32_R_TYPE(irel
->r_info
))
1654 case R_M32C_RL_JUMP
:
1657 case 0xbb: /* jmp.b */
1658 if (pcrel
>= 2 && pcrel
<= 9)
1661 /* Relax JMP.B -> JMP.S. We need to get rid of
1662 the following reloc though. */
1663 insn
[0] = 0x4a | ((p
<< 3) & 0x30) | (p
& 1);
1664 new_type
= R_M32C_NONE
;
1665 irel
->r_addend
= 0x10;
1671 case 0xce: /* jmp.w */
1672 if (pcrel
<= 128 && pcrel
>= -128)
1674 /* Relax JMP.W -> JMP.B */
1677 new_type
= R_M32C_8_PCREL
;
1683 case 0xcc: /* jmp.a */
1684 if (pcrel
<= 32768 && pcrel
>= -32768)
1686 /* Relax JMP.A -> JMP.W */
1690 new_type
= R_M32C_16_PCREL
;
1696 case 0xcd: /* jsr.a */
1697 if (pcrel
<= 32768 && pcrel
>= -32768)
1699 /* Relax JSR.A -> JSR.W */
1703 new_type
= R_M32C_16_PCREL
;
1711 case R_M32C_RL_2ADDR
:
1712 /* xSSS DDDx DDSS xxxx [src-disp] [dest-disp]*/
1718 /* prefix; remove it as far as the RL reloc is concerned. */
1723 enctbl
= m32c_addr_encodings
;
1724 enc
= ((einsn
[0] & 0x70) >> 2) | ((einsn
[1] & 0x30) >> 4);
1727 if (srel
->r_offset
== irel
->r_offset
+ posn
1728 && e
->new_encoding
!= enc
1729 && symval
<= e
->max_disp
)
1732 einsn
[0] |= (e
->new_encoding
& 0x1c) << 2;
1734 einsn
[1] |= (e
->new_encoding
& 0x03) << 4;
1735 gap_size
= e
->bytes
- enctbl
[e
->new_encoding
].bytes
;
1736 gap
= insn
+ posn
+ enctbl
[e
->new_encoding
].bytes
;
1737 new_type
= bytes_to_reloc
[enctbl
[e
->new_encoding
].bytes
];
1740 if (relax_relocs
== 2)
1746 case R_M32C_RL_1ADDR
:
1747 /* xxxx DDDx DDxx xxxx [disp] */
1753 /* prefix; remove it as far as the RL reloc is concerned. */
1758 enctbl
= m32c_addr_encodings
;
1761 /* srel, posn, and enc must be set here. */
1763 symval
= OFFSET_FOR_RELOC (srel
);
1764 enc
= ((einsn
[0] & 0x0e) << 1) | ((einsn
[1] & 0xc0) >> 6);
1767 if (srel
->r_offset
== irel
->r_offset
+ posn
1768 && e
->new_encoding
!= enc
1769 && symval
<= e
->max_disp
)
1772 einsn
[0] |= (e
->new_encoding
& 0x1c) >> 1;
1774 einsn
[1] |= (e
->new_encoding
& 0x03) << 6;
1775 gap_size
= e
->bytes
- enctbl
[e
->new_encoding
].bytes
;
1776 gap
= insn
+ posn
+ enctbl
[e
->new_encoding
].bytes
;
1777 new_type
= bytes_to_reloc
[enctbl
[e
->new_encoding
].bytes
];
1783 } /* Ends switch (reloc type) for m32c. */
1791 srel
->r_info
= ELF32_R_INFO (ELF32_R_SYM (srel
->r_info
), new_type
);
1793 /* Note that we've changed the relocs, section contents, etc. */
1794 elf_section_data (sec
)->relocs
= internal_relocs
;
1797 elf_section_data (sec
)->this_hdr
.contents
= contents
;
1798 free_contents
= NULL
;
1800 symtab_hdr
->contents
= (bfd_byte
*) intsyms
;
1801 free_intsyms
= NULL
;
1803 bytes_saved
+= gap_size
;
1805 if (! m32c_elf_relax_delete_bytes(abfd
, sec
, gap
- contents
, gap_size
))
1808 } /* next relocation */
1810 if (free_relocs
!= NULL
)
1816 if (free_contents
!= NULL
)
1818 if (! link_info
->keep_memory
)
1819 free (free_contents
);
1820 /* Cache the section contents for elf_link_input_bfd. */
1822 elf_section_data (sec
)->this_hdr
.contents
= contents
;
1824 free_contents
= NULL
;
1827 if (shndx_buf
!= NULL
)
1829 shndx_hdr
->contents
= NULL
;
1833 if (free_intsyms
!= NULL
)
1835 if (! link_info
->keep_memory
)
1836 free (free_intsyms
);
1837 /* Cache the symbols for elf_link_input_bfd. */
1840 symtab_hdr
->contents
= NULL
/* (unsigned char *) intsyms*/;
1843 free_intsyms
= NULL
;
1849 if (free_relocs
!= NULL
)
1851 if (free_contents
!= NULL
)
1852 free (free_contents
);
1853 if (shndx_buf
!= NULL
)
1855 shndx_hdr
->contents
= NULL
;
1858 if (free_intsyms
!= NULL
)
1859 free (free_intsyms
);
1863 /* Delete some bytes from a section while relaxing. */
1866 m32c_elf_relax_delete_bytes
1872 Elf_Internal_Shdr
*symtab_hdr
;
1873 Elf_Internal_Shdr
*shndx_hdr
;
1876 Elf_Internal_Rela
*irel
;
1877 Elf_Internal_Rela
*irelend
;
1878 Elf_Internal_Rela
*irelalign
;
1880 Elf_Internal_Sym
*isym
;
1881 Elf_Internal_Sym
*isymend
;
1882 Elf_Internal_Sym
*intsyms
;
1883 Elf_External_Sym_Shndx
*shndx_buf
;
1884 Elf_External_Sym_Shndx
*shndx
;
1885 struct elf_link_hash_entry
** sym_hashes
;
1886 struct elf_link_hash_entry
** end_hashes
;
1887 unsigned int symcount
;
1889 contents
= elf_section_data (sec
)->this_hdr
.contents
;
1891 /* The deletion must stop at the next ALIGN reloc for an aligment
1892 power larger than the number of bytes we are deleting. */
1896 irel
= elf_section_data (sec
)->relocs
;
1897 irelend
= irel
+ sec
->reloc_count
;
1899 /* Actually delete the bytes. */
1900 memmove (contents
+ addr
, contents
+ addr
+ count
, (size_t) (toaddr
- addr
- count
));
1903 /* Adjust all the relocs. */
1904 for (irel
= elf_section_data (sec
)->relocs
; irel
< irelend
; irel
++)
1906 /* Get the new reloc address. */
1907 if (irel
->r_offset
> addr
&& irel
->r_offset
< toaddr
)
1908 irel
->r_offset
-= count
;
1910 if (ELF32_R_TYPE(irel
->r_info
) == R_M32C_RL_JUMP
1911 && irel
->r_addend
== 0x10 /* one byte insn, no relocs */
1912 && irel
->r_offset
+ 1 < addr
1913 && irel
->r_offset
+ 7 > addr
)
1916 unsigned char *insn
= &contents
[irel
->r_offset
];
1918 /* This is a JMP.S, which we have to manually update. */
1919 if (elf32_m32c_machine (abfd
) == bfd_mach_m16c
)
1921 if ((*insn
& 0xf8) != 0x60)
1927 if ((*insn
& 0xce) != 0x4a)
1929 disp
= ((disp
& 0x30) >> 3) | (disp
& 1);
1931 if (irel
->r_offset
+ disp
+ 2 >= addr
+count
)
1934 if (elf32_m32c_machine (abfd
) == bfd_mach_m16c
)
1936 *insn
= (*insn
& 0xf8) | disp
;
1940 *insn
= (*insn
& 0xce) | ((disp
& 6) << 3) | (disp
& 1);
1946 /* Adjust the local symbols defined in this section. */
1947 symtab_hdr
= & elf_tdata (abfd
)->symtab_hdr
;
1948 intsyms
= (Elf_Internal_Sym
*) symtab_hdr
->contents
;
1950 isymend
= isym
+ symtab_hdr
->sh_info
;
1952 sec_shndx
= _bfd_elf_section_from_bfd_section (abfd
, sec
);
1953 shndx_hdr
= & elf_tdata (abfd
)->symtab_shndx_hdr
;
1954 shndx_buf
= (Elf_External_Sym_Shndx
*) shndx_hdr
->contents
;
1957 for (; isym
< isymend
; isym
++, shndx
= (shndx
? shndx
+ 1 : NULL
))
1960 if ((int) isym
->st_shndx
== sec_shndx
1961 && isym
->st_value
> addr
1962 && isym
->st_value
< toaddr
)
1964 isym
->st_value
-= count
;
1968 /* Now adjust the global symbols defined in this section. */
1969 symcount
= (symtab_hdr
->sh_size
/ sizeof (Elf32_External_Sym
)
1970 - symtab_hdr
->sh_info
);
1971 sym_hashes
= elf_sym_hashes (abfd
);
1972 // sym_hashes += symtab_hdr->sh_info;
1973 end_hashes
= sym_hashes
+ symcount
;
1975 for (; sym_hashes
< end_hashes
; sym_hashes
++)
1977 struct elf_link_hash_entry
* sym_hash
= * sym_hashes
;
1980 ( sym_hash
->root
.type
== bfd_link_hash_defined
1981 || sym_hash
->root
.type
== bfd_link_hash_defweak
)
1982 && sym_hash
->root
.u
.def
.section
== sec
1983 && sym_hash
->root
.u
.def
.value
> addr
1984 && sym_hash
->root
.u
.def
.value
< toaddr
)
1986 sym_hash
->root
.u
.def
.value
-= count
;
1994 #define ELF_ARCH bfd_arch_m32c
1995 #define ELF_MACHINE_CODE EM_M32C
1996 #define ELF_MAXPAGESIZE 0x1000
1999 #define TARGET_BIG_SYM bfd_elf32_m32c_vec
2000 #define TARGET_BIG_NAME "elf32-m32c"
2002 #define TARGET_LITTLE_SYM bfd_elf32_m32c_vec
2003 #define TARGET_LITTLE_NAME "elf32-m32c"
2006 #define elf_info_to_howto_rel NULL
2007 #define elf_info_to_howto m32c_info_to_howto_rela
2008 #define elf_backend_object_p m32c_elf_object_p
2009 #define elf_backend_relocate_section m32c_elf_relocate_section
2010 #define elf_backend_check_relocs m32c_elf_check_relocs
2011 #define elf_backend_object_p m32c_elf_object_p
2012 #define elf_symbol_leading_char ('_')
2013 #define elf_backend_always_size_sections \
2014 m32c_elf_always_size_sections
2015 #define elf_backend_finish_dynamic_sections \
2016 m32c_elf_finish_dynamic_sections
2018 #define elf_backend_can_gc_sections 1
2020 #define bfd_elf32_bfd_reloc_type_lookup m32c_reloc_type_lookup
2021 #define bfd_elf32_bfd_reloc_name_lookup m32c_reloc_name_lookup
2022 #define bfd_elf32_bfd_relax_section m32c_elf_relax_section
2023 #define bfd_elf32_bfd_set_private_flags m32c_elf_set_private_flags
2024 #define bfd_elf32_bfd_merge_private_bfd_data m32c_elf_merge_private_bfd_data
2025 #define bfd_elf32_bfd_print_private_bfd_data m32c_elf_print_private_bfd_data
2027 #include "elf32-target.h"