x86: Call rtype_to_howto to get reloc_howto_type pointer
* elf32-i386.c (elf_i386_relocate_section): Call elf_i386_rtype_to_howto to get reloc_howto_type pointer. * elf64-x86-64.c (elf_x86_64_relocate_section): Call elf_x86_64_rtype_to_howto to get reloc_howto_type pointer.
This commit is contained in:
parent
161d081c56
commit
76268e0274
|
@ -1,3 +1,10 @@
|
||||||
|
2018-12-20 H.J. Lu <hongjiu.lu@intel.com>
|
||||||
|
|
||||||
|
* elf32-i386.c (elf_i386_relocate_section): Call
|
||||||
|
elf_i386_rtype_to_howto to get reloc_howto_type pointer.
|
||||||
|
* elf64-x86-64.c (elf_x86_64_relocate_section): Call
|
||||||
|
elf_x86_64_rtype_to_howto to get reloc_howto_type pointer.
|
||||||
|
|
||||||
2018-12-18 Alan Modra <amodra@gmail.com>
|
2018-12-18 Alan Modra <amodra@gmail.com>
|
||||||
|
|
||||||
* Makefile.am (bfdinclude_HEADERS): Add bfd_stdint.h.
|
* Makefile.am (bfdinclude_HEADERS): Add bfd_stdint.h.
|
||||||
|
|
|
@ -2080,15 +2080,10 @@ elf_i386_relocate_section (bfd *output_bfd,
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((indx = r_type) >= R_386_standard
|
howto = elf_i386_rtype_to_howto (input_bfd, r_type);
|
||||||
&& ((indx = r_type - R_386_ext_offset) - R_386_standard
|
if (howto == NULL)
|
||||||
>= R_386_ext - R_386_standard)
|
|
||||||
&& ((indx = r_type - R_386_tls_offset) - R_386_ext
|
|
||||||
>= R_386_ext2 - R_386_ext))
|
|
||||||
return _bfd_unrecognized_reloc (input_bfd, input_section, r_type);
|
return _bfd_unrecognized_reloc (input_bfd, input_section, r_type);
|
||||||
|
|
||||||
howto = elf_howto_table + indx;
|
|
||||||
|
|
||||||
r_symndx = ELF32_R_SYM (rel->r_info);
|
r_symndx = ELF32_R_SYM (rel->r_info);
|
||||||
h = NULL;
|
h = NULL;
|
||||||
sym = NULL;
|
sym = NULL;
|
||||||
|
|
|
@ -2443,15 +2443,10 @@ elf_x86_64_relocate_section (bfd *output_bfd,
|
||||||
rel->r_info = htab->r_info (r_symndx, r_type);
|
rel->r_info = htab->r_info (r_symndx, r_type);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (r_type >= (int) R_X86_64_standard)
|
howto = elf_x86_64_rtype_to_howto (input_bfd, r_type);
|
||||||
|
if (howto == NULL)
|
||||||
return _bfd_unrecognized_reloc (input_bfd, input_section, r_type);
|
return _bfd_unrecognized_reloc (input_bfd, input_section, r_type);
|
||||||
|
|
||||||
if (r_type != (int) R_X86_64_32
|
|
||||||
|| ABI_64_P (output_bfd))
|
|
||||||
howto = x86_64_elf_howto_table + r_type;
|
|
||||||
else
|
|
||||||
howto = (x86_64_elf_howto_table
|
|
||||||
+ ARRAY_SIZE (x86_64_elf_howto_table) - 1);
|
|
||||||
h = NULL;
|
h = NULL;
|
||||||
sym = NULL;
|
sym = NULL;
|
||||||
sec = NULL;
|
sec = NULL;
|
||||||
|
|
Loading…
Reference in New Issue