summaryrefslogtreecommitdiff
path: root/bfd/elfcode.h
diff options
context:
space:
mode:
authorDaniel Jacobowitz <drow@false.org>2002-09-18 13:25:35 +0000
committerDaniel Jacobowitz <drow@false.org>2002-09-18 13:25:35 +0000
commit05a487dc8c398898e46d2ba52cc3e05f3f25b965 (patch)
tree5cee66b0a1d40fae894ada0bb53e797e569c697e /bfd/elfcode.h
parentcb7e422f1e2dbcd8da9eb807440e4b9e6a0e0f94 (diff)
downloadbinutils-gdb-05a487dc8c398898e46d2ba52cc3e05f3f25b965.tar.gz
* elfcode.h (elf_slurp_reloc_table_from_section): Check
correct relocation count.
Diffstat (limited to 'bfd/elfcode.h')
-rw-r--r--bfd/elfcode.h8
1 files changed, 7 insertions, 1 deletions
diff --git a/bfd/elfcode.h b/bfd/elfcode.h
index 7f9ed5fe3af..ca72307710a 100644
--- a/bfd/elfcode.h
+++ b/bfd/elfcode.h
@@ -1377,6 +1377,7 @@ elf_slurp_reloc_table_from_section (abfd, asect, rel_hdr, reloc_count,
arelent *relent;
unsigned int i;
int entsize;
+ long symcount;
allocated = (PTR) bfd_malloc (rel_hdr->sh_size);
if (allocated == NULL)
@@ -1419,9 +1420,14 @@ elf_slurp_reloc_table_from_section (abfd, asect, rel_hdr, reloc_count,
else
relent->address = rela.r_offset - asect->vma;
+ if (dynamic)
+ symcount = bfd_get_dynamic_symcount (abfd);
+ else
+ symcount = bfd_get_symcount (abfd);
+
if (ELF_R_SYM (rela.r_info) == 0)
relent->sym_ptr_ptr = bfd_abs_section_ptr->symbol_ptr_ptr;
- else if (ELF_R_SYM (rela.r_info) > bfd_get_dynamic_symcount (abfd))
+ else if (ELF_R_SYM (rela.r_info) > symcount)
{
(*_bfd_error_handler)
(_("%s(%s): relocation %d has invalid symbol index %ld"),