aoutm68k_exec.c revision 1.26 1 1.26 tsutsui /* $NetBSD: aoutm68k_exec.c,v 1.26 2010/10/15 16:51:09 tsutsui Exp $ */
2 1.1 scw
3 1.1 scw /*-
4 1.1 scw * Copyright (c) 2000 The NetBSD Foundation, Inc.
5 1.1 scw * All rights reserved.
6 1.1 scw *
7 1.1 scw * This code is derived from software contributed to The NetBSD Foundation
8 1.1 scw * by Steve C. Woodford.
9 1.1 scw *
10 1.1 scw * Redistribution and use in source and binary forms, with or without
11 1.1 scw * modification, are permitted provided that the following conditions
12 1.1 scw * are met:
13 1.1 scw * 1. Redistributions of source code must retain the above copyright
14 1.1 scw * notice, this list of conditions and the following disclaimer.
15 1.1 scw * 2. Redistributions in binary form must reproduce the above copyright
16 1.1 scw * notice, this list of conditions and the following disclaimer in the
17 1.1 scw * documentation and/or other materials provided with the distribution.
18 1.1 scw *
19 1.1 scw * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 1.1 scw * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 1.1 scw * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 1.1 scw * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 1.1 scw * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 1.1 scw * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 1.1 scw * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 1.1 scw * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 1.1 scw * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 1.1 scw * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 1.1 scw * POSSIBILITY OF SUCH DAMAGE.
30 1.1 scw */
31 1.8 lukem
32 1.8 lukem #include <sys/cdefs.h>
33 1.26 tsutsui __KERNEL_RCSID(0, "$NetBSD: aoutm68k_exec.c,v 1.26 2010/10/15 16:51:09 tsutsui Exp $");
34 1.1 scw
35 1.5 mrg #if defined(_KERNEL_OPT)
36 1.1 scw #include "opt_syscall_debug.h"
37 1.1 scw #endif
38 1.1 scw
39 1.1 scw #include <sys/param.h>
40 1.1 scw #include <sys/systm.h>
41 1.1 scw #include <sys/mount.h>
42 1.1 scw #include <sys/proc.h>
43 1.1 scw #include <sys/exec.h>
44 1.1 scw #include <sys/signalvar.h>
45 1.24 pooka #include <sys/syscallvar.h>
46 1.1 scw
47 1.19 fvdl #include <uvm/uvm_extern.h>
48 1.19 fvdl
49 1.1 scw #include <compat/aoutm68k/aoutm68k_syscall.h>
50 1.10 manu
51 1.1 scw extern struct sysent aoutm68k_sysent[];
52 1.1 scw extern char sigcode[], esigcode[];
53 1.21 dsl void aoutm68k_syscall_intern(struct proc *);
54 1.1 scw
55 1.13 chs struct uvm_object *emul_netbsd_aoutm68k_object;
56 1.13 chs
57 1.23 ad struct emul emul_netbsd_aoutm68k = {
58 1.25 chs .e_name = "aoutm68k",
59 1.26 tsutsui .e_path = NULL,
60 1.12 jdolecek #ifndef __HAVE_MINIMAL_EMUL
61 1.25 chs .e_flags = EMUL_HAS_SYS___syscall,
62 1.25 chs .e_errno = NULL,
63 1.25 chs .e_nosys = AOUTM68K_SYS_syscall,
64 1.25 chs .e_nsysent = AOUTM68K_SYS_NSYSENT,
65 1.12 jdolecek #endif
66 1.25 chs .e_sysent = aoutm68k_sysent,
67 1.1 scw #ifdef SYSCALL_DEBUG
68 1.25 chs .e_syscallnames = syscallnames,
69 1.1 scw #endif
70 1.25 chs .e_sendsig = sendsig,
71 1.25 chs .e_trapsignal = trapsignal,
72 1.25 chs .e_tracesig = NULL,
73 1.25 chs .e_sigcode = sigcode,
74 1.25 chs .e_esigcode = esigcode,
75 1.25 chs .e_sigobject = &emul_netbsd_aoutm68k_object,
76 1.25 chs .e_setregs = setregs,
77 1.25 chs .e_proc_exec = NULL,
78 1.25 chs .e_proc_fork = NULL,
79 1.25 chs .e_proc_exit = NULL,
80 1.25 chs .e_lwp_fork = NULL,
81 1.25 chs .e_lwp_exit = NULL,
82 1.25 chs .e_syscall_intern = aoutm68k_syscall_intern,
83 1.25 chs .e_sysctlovly = NULL,
84 1.25 chs .e_fault = NULL,
85 1.25 chs .e_vm_default_addr = uvm_default_mapaddr,
86 1.25 chs .e_usertrap = NULL,
87 1.25 chs .e_sa = NULL,
88 1.25 chs .e_ucsize = 0,
89 1.25 chs .e_startlwp = NULL
90 1.1 scw };
91