diff options
author | Alan Modra <amodra@bigpond.net.au> | 2008-08-01 12:21:28 +0000 |
---|---|---|
committer | Alan Modra <amodra@bigpond.net.au> | 2008-08-01 12:21:28 +0000 |
commit | e10a4f35c0495cf224fa51138c83b62f1b7fa7fe (patch) | |
tree | 4985f7685f0fe813d9e6f6c5d2ffda18ffb9d58c /bfd/elfcode.h | |
parent | 85ac20d14d44b9203c6b4150c25e0f8a5016af58 (diff) | |
download | binutils-redhat-e10a4f35c0495cf224fa51138c83b62f1b7fa7fe.tar.gz |
* elfcore.h (elf_core_file_p): Ensure we have a backend match
with the correct arch size before rejecting the generic fallback.
* elfcode.h (elf_object_p): Likewise. Ensure arch size matches
before accepting a target.
Diffstat (limited to 'bfd/elfcode.h')
-rw-r--r-- | bfd/elfcode.h | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/bfd/elfcode.h b/bfd/elfcode.h index c356638d08..b42229f007 100644 --- a/bfd/elfcode.h +++ b/bfd/elfcode.h @@ -574,6 +574,8 @@ elf_object_p (bfd *abfd) goto got_wrong_format_error; ebd = get_elf_backend_data (abfd); + if (ebd->s->arch_size != ARCH_SIZE) + goto got_wrong_format_error; /* Check that the ELF e_machine field matches what this particular BFD format expects. */ @@ -595,6 +597,8 @@ elf_object_p (bfd *abfd) if ((*target_ptr)->flavour != bfd_target_elf_flavour) continue; back = xvec_get_elf_backend_data (*target_ptr); + if (back->s->arch_size != ARCH_SIZE) + continue; if (back->elf_machine_code == i_ehdrp->e_machine || (back->elf_machine_alt1 != 0 && back->elf_machine_alt1 == i_ehdrp->e_machine) |