mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-30 12:44:10 +08:00
Handle x86 VTINHERIT/VTENTRY relocs when deleting relocations
* elf32-i386.c (elf_i386_relocate_section): Handle VTINHERIT and VTENTRY relocations when deleting relocations. * elf64-x86-64.c (elf_x86_64_relocate_section): Likewise.
This commit is contained in:
parent
2d5da47320
commit
18954b29a1
@ -1,3 +1,9 @@
|
||||
2015-11-10 H.J. Lu <hongjiu.lu@intel.com>
|
||||
|
||||
* elf32-i386.c (elf_i386_relocate_section): Handle VTINHERIT
|
||||
and VTENTRY relocations when deleting relocations.
|
||||
* elf64-x86-64.c (elf_x86_64_relocate_section): Likewise.
|
||||
|
||||
2015-11-10 H.J. Lu <hongjiu.lu@intel.com>
|
||||
|
||||
* elf32-i386.c (elf_i386_relocate_section): Properly move
|
||||
|
@ -3647,7 +3647,11 @@ elf_i386_relocate_section (bfd *output_bfd,
|
||||
r_type = ELF32_R_TYPE (rel->r_info);
|
||||
if (r_type == R_386_GNU_VTINHERIT
|
||||
|| r_type == R_386_GNU_VTENTRY)
|
||||
continue;
|
||||
{
|
||||
if (wrel != rel)
|
||||
*wrel = *rel;
|
||||
continue;
|
||||
}
|
||||
|
||||
if ((indx = r_type) >= R_386_standard
|
||||
&& ((indx = r_type - R_386_ext_offset) - R_386_standard
|
||||
|
@ -3904,7 +3904,11 @@ elf_x86_64_relocate_section (bfd *output_bfd,
|
||||
r_type = ELF32_R_TYPE (rel->r_info);
|
||||
if (r_type == (int) R_X86_64_GNU_VTINHERIT
|
||||
|| r_type == (int) R_X86_64_GNU_VTENTRY)
|
||||
continue;
|
||||
{
|
||||
if (wrel != rel)
|
||||
*wrel = *rel;
|
||||
continue;
|
||||
}
|
||||
|
||||
if (r_type >= (int) R_X86_64_standard)
|
||||
{
|
||||
|
Loading…
Reference in New Issue
Block a user