patch-2.4.0-test4 linux/fs/binfmt_elf.c
Next file: linux/fs/block_dev.c
Previous file: linux/drivers/video/vga_font.c
Back to the patch index
Back to the overall index
- Lines: 43
- Date:
Tue Jul 11 15:43:45 2000
- Orig file:
v2.4.0-test3/linux/fs/binfmt_elf.c
- Orig date:
Mon Jul 10 16:47:25 2000
diff -u --recursive --new-file v2.4.0-test3/linux/fs/binfmt_elf.c linux/fs/binfmt_elf.c
@@ -220,7 +220,7 @@
if (interp_elf_ex->e_type != ET_EXEC &&
interp_elf_ex->e_type != ET_DYN)
goto out;
- if (!elf_check_arch(interp_elf_ex->e_machine))
+ if (!elf_check_arch(interp_elf_ex))
goto out;
if (!interpreter->f_op->mmap)
goto out;
@@ -405,23 +405,8 @@
if (elf_ex.e_type != ET_EXEC && elf_ex.e_type != ET_DYN)
goto out;
- if (!elf_check_arch(elf_ex.e_machine))
+ if (!elf_check_arch(&elf_ex))
goto out;
-#if defined(__mips__) && !defined(__mips64)
- /* IRIX5 binaries handled elsewhere. */
- if (elf_ex.e_flags & EF_MIPS_ARCH) {
- retval = -ENOEXEC;
- goto out;
- }
-#endif
-#if defined(__mips__) && defined(__mips64)
- /* Linux/MIPS 32-bit binaries handled elsewhere. */
- if (sizeof(elf_caddr_t) == 8 &&
- elf_ex.e_ident[EI_CLASS] == ELFCLASS32) {
- retval = -ENOEXEC;
- goto out;
- }
-#endif
if (!bprm->file->f_op||!bprm->file->f_op->mmap)
goto out;
@@ -794,7 +779,7 @@
/* First of all, some simple consistency checks */
if (elf_ex.e_type != ET_EXEC || elf_ex.e_phnum > 2 ||
- !elf_check_arch(elf_ex.e_machine) || !file->f_op->mmap)
+ !elf_check_arch(&elf_ex) || !file->f_op->mmap)
goto out;
/* Now read in all of the header information */
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)