From a873f25a2297eca984e951075e5c0c367d07bcc8 Mon Sep 17 00:00:00 2001 From: Alexandre Oliva Date: Wed, 9 Jun 2004 08:31:28 +0000 Subject: [PATCH] * elf-m10300.c (_bfd_mn10300_elf_reloc_type_class): New. (elf_backend_reloc_type_class): New. --- bfd/ChangeLog | 5 +++++ bfd/elf-m10300.c | 22 ++++++++++++++++++++++ 2 files changed, 27 insertions(+) diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 8fda1ff07c2..4d2a84a9fd8 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,8 @@ +2004-06-09 Alexandre Oliva + + * elf-m10300.c (_bfd_mn10300_elf_reloc_type_class): New. + (elf_backend_reloc_type_class): New. + 2004-06-08 Mark Kettenis * configure.in (hppa*-*-netbsd*, hppa*-*-openbsd): Set COREFILE to diff --git a/bfd/elf-m10300.c b/bfd/elf-m10300.c index d61df463570..9f5ab836a61 100644 --- a/bfd/elf-m10300.c +++ b/bfd/elf-m10300.c @@ -4866,6 +4866,25 @@ _bfd_mn10300_elf_finish_dynamic_sections (output_bfd, info) return TRUE; } +/* Classify relocation types, such that combreloc can sort them + properly. */ + +static enum elf_reloc_type_class +_bfd_mn10300_elf_reloc_type_class (const Elf_Internal_Rela *rela) +{ + switch ((int) ELF32_R_TYPE (rela->r_info)) + { + case R_MN10300_RELATIVE: + return reloc_class_relative; + case R_MN10300_JMP_SLOT: + return reloc_class_plt; + case R_MN10300_COPY: + return reloc_class_copy; + default: + return reloc_class_normal; + } +} + #ifndef ELF_ARCH #define TARGET_LITTLE_SYM bfd_elf32_mn10300_vec #define TARGET_LITTLE_NAME "elf32-mn10300" @@ -4914,6 +4933,9 @@ _bfd_mn10300_elf_finish_dynamic_sections (output_bfd, info) #define elf_backend_finish_dynamic_sections \ _bfd_mn10300_elf_finish_dynamic_sections +#define elf_backend_reloc_type_class \ + _bfd_mn10300_elf_reloc_type_class + #define elf_backend_want_got_plt 1 #define elf_backend_plt_readonly 1 #define elf_backend_want_plt_sym 0 -- 2.30.2