NetBSD-5.0.2/sys/arch/sun2/sun2/genassym.cf

#	$NetBSD: genassym.cf,v 1.10 2008/09/20 18:29:05 tsutsui Exp $

#
# Copyright (c) 1982, 1990, 1993
#	The Regents of the University of California.  All rights reserved.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions
# are met:
# 1. Redistributions of source code must retain the above copyright
#    notice, this list of conditions and the following disclaimer.
# 2. Redistributions in binary form must reproduce the above copyright
#    notice, this list of conditions and the following disclaimer in the
#    documentation and/or other materials provided with the distribution.
# 3. Neither the name of the University nor the names of its contributors
#    may be used to endorse or promote products derived from this software
#    without specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
# ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
# SUCH DAMAGE.
#
#	from: @(#)genassym.c	8.3 (Berkeley) 1/4/94
#

#
# Copyright (c) 1994, 1995 Gordon W. Ross
# Copyright (c) 1993 Adam Glass
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions
# are met:
# 1. Redistributions of source code must retain the above copyright
#    notice, this list of conditions and the following disclaimer.
# 2. Redistributions in binary form must reproduce the above copyright
#    notice, this list of conditions and the following disclaimer in the
#    documentation and/or other materials provided with the distribution.
# 3. All advertising materials mentioning features or use of this software
#    must display the following acknowledgement:
#	This product includes software developed by the University of
#	California, Berkeley and its contributors.
# 4. Neither the name of the University nor the names of its contributors
#    may be used to endorse or promote products derived from this software
#    without specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
# ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
# SUCH DAMAGE.
#
#	from: @(#)genassym.c	8.3 (Berkeley) 1/4/94
#

if defined(_KERNEL_OPT)
include "opt_compat_svr4.h"
endif

include <sys/param.h>
include <sys/cdefs.h>
include <sys/errno.h>
include <sys/proc.h>
include <sys/syscall.h>

include <uvm/uvm_extern.h>

ifdef COMPAT_SVR4
include <compat/svr4/svr4_syscall.h>
include <compat/svr4/svr4_ucontext.h>
endif

include <machine/cpu.h>
include <machine/dvma.h>
include <machine/mon.h>
include <machine/pcb.h>
include <machine/pmap.h>
include <machine/psl.h>
include <machine/pte.h>
include <machine/vmparam.h>

include <sun2/sun2/buserr.h>
include <sun2/sun2/control.h>
include <sun2/sun2/fc.h>
include <sun2/sun2/enable.h>

include <dev/ic/am9513reg.h>

# XXX: for copy.s
define	M68010			1

# bus error stuff
define	BUSERR_REG			BUSERR_REG
define	BUSERR_PROTERR			BUSERR_PROTERR

# 68k isms
define	PSL_LOWIPL			PSL_LOWIPL
define	PSL_HIGHIPL			PSL_HIGHIPL
define	PSL_USER			PSL_USER
define	PSL_S				PSL_S
define	PSL_TS				PSL_T | PSL_S
define	FC_CONTROL			FC_CONTROL
define	FC_SUPERD			FC_SUPERD
define	FC_USERD			FC_USERD

# sun2 control space isms
define	SCONTEXT_REG			SCONTEXT_REG
define	CONTEXT_REG			CONTEXT_REG
define	CONTEXT_NUM			CONTEXT_NUM
define	SYSTEM_ENAB			SYSTEM_ENAB
define	ENA_INTS			ENA_INTS
define	SEGMAP_BASE			SEGMAP_BASE

# sun2 memory map
define	USRSTACK			USRSTACK
define	SUN2_MONSTART			SUN2_MONSTART
define	SUN2_PROM_BASE			SUN2_PROM_BASE
define	SUN2_MONEND			SUN2_MONEND

# sun2 clock
define	AM9513_CLK_CMD			AM9513_CLK_CMD
define	SUN2_CLK_TIMER_CLEAR_OUTPUT	AM9513_CMD_CLEAR_OUTPUT(AM9513_TIMER2)

# kernel-isms
define	KERNBASE			KERNBASE
define	USPACE				USPACE
define	PAGE_SIZE			PAGE_SIZE
define	NBPG				NBPG
define	NBSG				NBSG

# system calls
define	SYS_exit			SYS_exit
define	SYS_compat_16___sigreturn14	SYS_compat_16___sigreturn14
define	SYS_compat_13_sigreturn13	SYS_compat_13_sigreturn13

# errno-isms
define	EFAULT				EFAULT
define	ENAMETOOLONG			ENAMETOOLONG

# trap types: locore.s includes trap.h

#
# unix structure-isms
#

# lwp & proc fields and values
define	L_ADDR			offsetof(struct lwp, l_addr)
define	L_PRIORITY		offsetof(struct lwp, l_priority)
define	L_STAT			offsetof(struct lwp, l_stat)
define	L_WCHAN			offsetof(struct lwp, l_wchan)
define	L_PROC			offsetof(struct lwp, l_proc)
define	L_MD_REGS		offsetof(struct lwp, l_md.md_regs)
define	L_MD_FLAGS		offsetof(struct lwp, l_md.md_flags)
define	P_FLAG			offsetof(struct proc, p_flag)
define	P_RASLIST		offsetof(struct proc, p_raslist)
define	P_VMSPACE		offsetof(struct proc, p_vmspace)

# lwp fields and values

define	LSSLEEP			LSSLEEP
define	LSRUN			LSRUN
define	LSONPROC		LSONPROC

# XXX: HP-UX trace bit?

# VM/pmap structure fields
define	VM_PMAP			offsetof(struct vmspace, vm_map.pmap)
define	PM_CTXNUM		offsetof(struct pmap, pm_ctxnum)

# pcb offsets
define	PCB_FLAGS		offsetof(struct pcb, pcb_flags)
define	PCB_PS			offsetof(struct pcb, pcb_ps)
define	PCB_USP			offsetof(struct pcb, pcb_usp)
define	PCB_REGS		offsetof(struct pcb, pcb_regs[0])
define	PCB_ONFAULT		offsetof(struct pcb, pcb_onfault)
define	PCB_FPCTX		offsetof(struct pcb, pcb_fpregs)
define	SIZEOF_PCB		sizeof(struct pcb)

# frame offsets
define	TF_PC			offsetof(struct frame, f_pc)

# exception frame offset/sizes
define	FR_SP			offsetof(struct trapframe, tf_regs[15])
define	FR_ADJ			offsetof(struct trapframe, tf_stackadj)
define	FR_HW			offsetof(struct trapframe, tf_sr)
define	FR_SIZE			sizeof(struct trapframe)

# FP frame offsets
define	FPF_REGS		offsetof(struct fpframe, fpf_regs[0])
define	FPF_FPCR		offsetof(struct fpframe, fpf_fpcr)

# SVR4 binary compatibility
ifdef COMPAT_SVR4
define	SVR4_SIGF_HANDLER	offsetof(struct svr4_sigframe, sf_handler)
define	SVR4_SIGF_UC		offsetof(struct svr4_sigframe, sf_uc)
define	SVR4_SYS_context	SVR4_SYS_context
define	SVR4_SYS_exit		SVR4_SYS_exit
define	SVR4_SETCONTEXT		SVR4_SETCONTEXT
endif