summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Clifton <nickc@redhat.com>2005-04-27 10:09:43 +0000
committerNick Clifton <nickc@redhat.com>2005-04-27 10:09:43 +0000
commit360c0a7a18390e712988f4461ba6be7ac10b9443 (patch)
treeedae0c95858ecb54c8c81de0569f196c84e344bb
parent8e0ace596b07bebaf006e7d92c75bb9dbc4949d8 (diff)
downloadbinutils-redhat-360c0a7a18390e712988f4461ba6be7ac10b9443.tar.gz
(elf_link_input_bfd): Handle the case where a badly formatted input file results
in a reloc which has no associated global symbol
-rw-r--r--bfd/ChangeLog6
-rw-r--r--bfd/elflink.c17
2 files changed, 23 insertions, 0 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog
index bf49cc0e42..2e70d771a1 100644
--- a/bfd/ChangeLog
+++ b/bfd/ChangeLog
@@ -1,3 +1,9 @@
+2005-04-27 Nick Clifton <nickc@redhat.com>
+
+ * elflink.c (elf_link_input_bfd): Handle the case where a badly
+ formatted input file results in a reloc which has no associated
+ global symbol.
+
2005-04-26 Jerome Guitton <guitton@gnat.com>
* bfd.m4 (BFD_NEED_DECLARATION): Restore.
diff --git a/bfd/elflink.c b/bfd/elflink.c
index cd9131ef38..bf2178090c 100644
--- a/bfd/elflink.c
+++ b/bfd/elflink.c
@@ -7019,6 +7019,23 @@ elf_link_input_bfd (struct elf_final_link_info *finfo, bfd *input_bfd)
&& finfo->sections[r_symndx] == NULL))
{
h = sym_hashes[r_symndx - extsymoff];
+
+ /* Badly formatted input files can contain relocs that
+ reference non-existant symbols. Check here so that
+ we do not seg fault. */
+ if (h == NULL)
+ {
+ char buffer [32];
+
+ sprintf_vma (buffer, rel->r_info);
+ (*_bfd_error_handler)
+ (_("error: %B contains a reloc (0x%s) for section %A "
+ "that references a non-existent global symbol"),
+ input_bfd, o, buffer);
+ bfd_set_error (bfd_error_bad_value);
+ return FALSE;
+ }
+
while (h->root.type == bfd_link_hash_indirect
|| h->root.type == bfd_link_hash_warning)
h = (struct elf_link_hash_entry *) h->root.u.i.link;