diff options
author | Alan Modra <amodra@gmail.com> | 2007-06-29 01:51:55 +0000 |
---|---|---|
committer | Alan Modra <amodra@gmail.com> | 2007-06-29 01:51:55 +0000 |
commit | 375de94a5e426b8277598a5f4d9e036b4b5d8b30 (patch) | |
tree | 43ac96883805f71d7db6ab467a18340583635798 /bfd/elf32-ppc.c | |
parent | 7d3287cb717540c60f0491587c29d523b4e38dfd (diff) | |
download | gdb-375de94a5e426b8277598a5f4d9e036b4b5d8b30.zip gdb-375de94a5e426b8277598a5f4d9e036b4b5d8b30.tar.gz gdb-375de94a5e426b8277598a5f4d9e036b4b5d8b30.tar.bz2 |
* elf32-ppc.c (ppc_elf_info_to_howto): Check for invalid relocation
types.
Diffstat (limited to 'bfd/elf32-ppc.c')
-rw-r--r-- | bfd/elf32-ppc.c | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/bfd/elf32-ppc.c b/bfd/elf32-ppc.c index 0e36be6..b84f0af 100644 --- a/bfd/elf32-ppc.c +++ b/bfd/elf32-ppc.c @@ -1607,6 +1607,17 @@ ppc_elf_info_to_howto (bfd *abfd ATTRIBUTE_UNUSED, BFD_ASSERT (ELF32_R_TYPE (dst->r_info) < (unsigned int) R_PPC_max); cache_ptr->howto = ppc_elf_howto_table[ELF32_R_TYPE (dst->r_info)]; + + /* Just because the above assert didn't trigger doesn't mean that + ELF32_R_TYPE (dst->r_info) is necessarily a valid relocation. */ + if (!cache_ptr->howto) + { + (*_bfd_error_handler) (_("%B: invalid relocation type %d"), + abfd, ELF32_R_TYPE (dst->r_info)); + bfd_set_error (bfd_error_bad_value); + + cache_ptr->howto = ppc_elf_howto_table[R_PPC_NONE]; + } } /* Handle the R_PPC_ADDR16_HA and R_PPC_REL16_HA relocs. */ |