Home | History | Annotate | Line # | Download | only in aoutm68k
      1  1.30  pgoyette /*	$NetBSD: aoutm68k_exec.c,v 1.30 2018/08/10 21:44:58 pgoyette 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.30  pgoyette __KERNEL_RCSID(0, "$NetBSD: aoutm68k_exec.c,v 1.30 2018/08/10 21:44:58 pgoyette 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.30  pgoyette extern const uint32_t aoutm68k_sysent_nomodbits[];
     53   1.1       scw extern char sigcode[], esigcode[];
     54  1.21       dsl void aoutm68k_syscall_intern(struct proc *);
     55   1.1       scw 
     56  1.13       chs struct uvm_object *emul_netbsd_aoutm68k_object;
     57  1.13       chs 
     58  1.23        ad struct emul emul_netbsd_aoutm68k = {
     59  1.25       chs 	.e_name =		"aoutm68k",
     60  1.26   tsutsui 	.e_path =		NULL,
     61  1.12  jdolecek #ifndef __HAVE_MINIMAL_EMUL
     62  1.25       chs 	.e_flags =		EMUL_HAS_SYS___syscall,
     63  1.25       chs 	.e_errno =		NULL,
     64  1.25       chs 	.e_nosys =		AOUTM68K_SYS_syscall,
     65  1.25       chs 	.e_nsysent =		AOUTM68K_SYS_NSYSENT,
     66  1.12  jdolecek #endif
     67  1.25       chs 	.e_sysent =		aoutm68k_sysent,
     68  1.30  pgoyette 	.e_nomodbits =		aoutm68k_sysent_nomodbits,
     69   1.1       scw #ifdef SYSCALL_DEBUG
     70  1.25       chs 	.e_syscallnames =	syscallnames,
     71   1.1       scw #endif
     72  1.25       chs 	.e_sendsig =		sendsig,
     73  1.25       chs 	.e_trapsignal =		trapsignal,
     74  1.25       chs 	.e_sigcode =		sigcode,
     75  1.25       chs 	.e_esigcode =		esigcode,
     76  1.25       chs 	.e_sigobject =		&emul_netbsd_aoutm68k_object,
     77  1.25       chs 	.e_setregs =		setregs,
     78  1.25       chs 	.e_proc_exec =		NULL,
     79  1.25       chs 	.e_proc_fork =		NULL,
     80  1.25       chs 	.e_proc_exit =		NULL,
     81  1.25       chs 	.e_lwp_fork =		NULL,
     82  1.25       chs 	.e_lwp_exit =		NULL,
     83  1.25       chs 	.e_syscall_intern =	aoutm68k_syscall_intern,
     84  1.25       chs 	.e_sysctlovly =		NULL,
     85  1.25       chs 	.e_vm_default_addr =	uvm_default_mapaddr,
     86  1.25       chs 	.e_usertrap =		NULL,
     87  1.25       chs 	.e_ucsize =		0,
     88  1.25       chs 	.e_startlwp =		NULL
     89   1.1       scw };
     90