From fca6ae69c41882f5adfba05da7d932b7c8bc2153 Mon Sep 17 00:00:00 2001 From: "H.J. Lu" Date: Wed, 20 May 2015 07:55:45 -0700 Subject: [PATCH] Skip extra relocations in .rel.plt/.rela.plt Extra relocations may be added to the .rel.plt/.rela.plt section, which are unrelated to PLT. We should skip them when retrieving PLT entry symbol values. PR binutils/18437 * elf32-i386.c (elf_i386_get_plt_sym_val): Skip extra relocations in .rel.plt/.rela.plt. * elf64-x86-64.c (elf_x86_64_get_plt_sym_val): Likewise. --- bfd/ChangeLog | 7 +++++++ bfd/elf32-i386.c | 5 +++++ bfd/elf64-x86-64.c | 5 +++++ 3 files changed, 17 insertions(+) diff --git a/bfd/ChangeLog b/bfd/ChangeLog index b5e4f39718d..87a0bffb459 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,10 @@ +2015-05-26 H.J. Lu + + PR binutils/18437 + * elf32-i386.c (elf_i386_get_plt_sym_val): Skip extra relocations + in .rel.plt/.rela.plt. + * elf64-x86-64.c (elf_x86_64_get_plt_sym_val): Likewise. + 2015-05-19 Jiong Wang * elfnn-aarch64.c (aarch64_tls_transition_without_check): Sort diff --git a/bfd/elf32-i386.c b/bfd/elf32-i386.c index c6ff7463a35..23d50e1193d 100644 --- a/bfd/elf32-i386.c +++ b/bfd/elf32-i386.c @@ -5260,6 +5260,11 @@ bad_return: abort (); plt_sym_val[reloc_index] = plt->vma + plt_offset; plt_offset += bed->plt->plt_entry_size; + + /* PR binutils/18437: Skip extra relocations in the .rel.plt + section. */ + if (plt_offset >= plt->size) + break; } free (plt_contents); diff --git a/bfd/elf64-x86-64.c b/bfd/elf64-x86-64.c index 01df2308ea4..4428f97e9b4 100644 --- a/bfd/elf64-x86-64.c +++ b/bfd/elf64-x86-64.c @@ -5649,6 +5649,11 @@ bad_return: else plt_sym_val[reloc_index] = plt->vma + plt_offset; plt_offset += bed->plt_entry_size; + + /* PR binutils/18437: Skip extra relocations in the .rela.plt + section. */ + if (plt_offset >= plt->size) + break; } free (plt_contents); -- 2.30.2