diff options
author | das <das@FreeBSD.org> | 2004-11-27 06:46:45 +0000 |
---|---|---|
committer | das <das@FreeBSD.org> | 2004-11-27 06:46:45 +0000 |
commit | 7f13dc5af0e2ff7946d78cc129ec850a69a53637 (patch) | |
tree | 86efb4b8942b20d8d54948cf17604123a221f8d9 /sys/compat | |
parent | 86bc3e16fcede40fa3914bcf8e002db9f36cff70 (diff) | |
download | FreeBSD-src-7f13dc5af0e2ff7946d78cc129ec850a69a53637.zip FreeBSD-src-7f13dc5af0e2ff7946d78cc129ec850a69a53637.tar.gz |
Axe the semblance of support for PECOFF and Linux a.out core dumps.
Diffstat (limited to 'sys/compat')
-rw-r--r-- | sys/compat/pecoff/imgact_pecoff.c | 68 |
1 files changed, 1 insertions, 67 deletions
diff --git a/sys/compat/pecoff/imgact_pecoff.c b/sys/compat/pecoff/imgact_pecoff.c index 0efd794..8371913 100644 --- a/sys/compat/pecoff/imgact_pecoff.c +++ b/sys/compat/pecoff/imgact_pecoff.c @@ -66,7 +66,6 @@ __FBSDID("$FreeBSD$"); #include <vm/vm_object.h> #include <vm/vm_extern.h> -#include <sys/user.h> #include <sys/exec.h> #include <sys/kernel.h> #include <sys/module.h> @@ -79,13 +78,8 @@ __FBSDID("$FreeBSD$"); #include "opt_pecoff.h" -#define uarea_pages 1 - #define PECOFF_PE_SIGNATURE "PE\0\0" static int pecoff_fixup(register_t **, struct image_params *); -static int -pecoff_coredump(register struct thread *, register struct vnode *, - off_t); #ifndef PECOFF_DEBUG #define DPRINTF(a) #else @@ -106,7 +100,7 @@ static struct sysentvec pecoff_sysvec = { &szsigcode, 0, "FreeBSD PECoff", - pecoff_coredump, + NULL, NULL, MINSIGSTKSZ, PAGE_SIZE, @@ -167,66 +161,6 @@ pecoff_fixup(register_t ** stack_base, struct image_params * imgp) return 0; } - -static int -pecoff_coredump(register struct thread * td, register struct vnode * vp, - off_t limit) -{ - register struct ucred *cred = td->td_ucred; - struct proc *p = td->td_proc; - register struct vmspace *vm = p->p_vmspace; - char *tempuser; - int error; -#ifdef PECOFF_DEBUG - struct vm_map *map; - struct vm_map_entry *ent; - struct reg regs; - -#endif - if (ctob((uarea_pages + kstack_pages) + vm->vm_dsize + vm->vm_ssize) >= - limit) - return (EFAULT); - tempuser = malloc(ctob(uarea_pages + kstack_pages), M_TEMP, - M_WAITOK | M_ZERO); - if (tempuser == NULL) - return (ENOMEM); - PROC_LOCK(p); - fill_user(p, (struct user *)tempuser); - PROC_UNLOCK(p); - bcopy(td->td_frame, - tempuser + ctob(uarea_pages) + - ((caddr_t)td->td_frame - (caddr_t)td->td_kstack), - sizeof(struct trapframe)); -#if PECOFF_DEBUG - fill_regs(td, ®s); - printf("EIP%x\n", regs.r_eip); - printf("EAX%x EBX%x ECX%x EDI%x\n", - regs.r_eax, regs.r_ebx, regs.r_ecx, regs.r_edi); - map = &vm->vm_map; - ent = &map->header; - printf("%p %p %p\n", ent, ent->prev, ent->next); -#endif - error = vn_rdwr(UIO_WRITE, vp, (caddr_t)tempuser, - ctob(uarea_pages + kstack_pages), - (off_t)0, UIO_SYSSPACE, IO_UNIT, cred, NOCRED, - (int *)NULL, td); - free(tempuser, M_TEMP); - if (error == 0) - error = vn_rdwr_inchunks(UIO_WRITE, vp, vm->vm_daddr, - (int)ctob(vm->vm_dsize), - (off_t)ctob((uarea_pages + kstack_pages)), - UIO_USERSPACE, IO_UNIT, cred, NOCRED, NULL, td); - if (error == 0) - error = vn_rdwr_inchunks(UIO_WRITE, vp, - (caddr_t)trunc_page(USRSTACK - ctob(vm->vm_ssize)), - round_page(ctob(vm->vm_ssize)), - (off_t)ctob((uarea_pages + kstack_pages)) + - ctob(vm->vm_dsize), - UIO_USERSPACE, IO_UNIT, cred, NOCRED, NULL, td); - return (error); - -} - static int pecoff_load_section(struct thread * td, struct vmspace * vmspace, struct vnode * vp, vm_offset_t offset, caddr_t vmaddr, size_t memsz, size_t filsz, vm_prot_t prot) { |