Home | History | Annotate | Line # | Download | only in sun3x
      1 #	$NetBSD: genassym.cf,v 1.18 2024/01/14 22:34:54 thorpej Exp $
      2 
      3 #
      4 # Copyright (c) 1982, 1990, 1993
      5 #	The Regents of the University of California.  All rights reserved.
      6 #
      7 # Redistribution and use in source and binary forms, with or without
      8 # modification, are permitted provided that the following conditions
      9 # are met:
     10 # 1. Redistributions of source code must retain the above copyright
     11 #    notice, this list of conditions and the following disclaimer.
     12 # 2. Redistributions in binary form must reproduce the above copyright
     13 #    notice, this list of conditions and the following disclaimer in the
     14 #    documentation and/or other materials provided with the distribution.
     15 # 3. Neither the name of the University nor the names of its contributors
     16 #    may be used to endorse or promote products derived from this software
     17 #    without specific prior written permission.
     18 #
     19 # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     20 # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     21 # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     22 # ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     23 # FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     24 # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     25 # OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     26 # HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     27 # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     28 # OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     29 # SUCH DAMAGE.
     30 #
     31 #	from: @(#)genassym.c	8.3 (Berkeley) 1/4/94
     32 #
     33 
     34 #
     35 # Copyright (c) 1994, 1995 Gordon W. Ross
     36 # Copyright (c) 1993 Adam Glass
     37 #
     38 # Redistribution and use in source and binary forms, with or without
     39 # modification, are permitted provided that the following conditions
     40 # are met:
     41 # 1. Redistributions of source code must retain the above copyright
     42 #    notice, this list of conditions and the following disclaimer.
     43 # 2. Redistributions in binary form must reproduce the above copyright
     44 #    notice, this list of conditions and the following disclaimer in the
     45 #    documentation and/or other materials provided with the distribution.
     46 # 3. All advertising materials mentioning features or use of this software
     47 #    must display the following acknowledgement:
     48 #	This product includes software developed by the University of
     49 #	California, Berkeley and its contributors.
     50 # 4. Neither the name of the University nor the names of its contributors
     51 #    may be used to endorse or promote products derived from this software
     52 #    without specific prior written permission.
     53 #
     54 # THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     55 # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     56 # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     57 # ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     58 # FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     59 # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     60 # OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     61 # HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     62 # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     63 # OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     64 # SUCH DAMAGE.
     65 #
     66 #	from: @(#)genassym.c	8.3 (Berkeley) 1/4/94
     67 #
     68 
     69 include <sys/param.h>
     70 include <sys/cdefs.h>
     71 include <sys/errno.h>
     72 include <sys/proc.h>
     73 include <sys/syscall.h>
     74 
     75 include <uvm/uvm_extern.h>
     76 
     77 include <machine/cpu.h>
     78 include <machine/dvma.h>
     79 include <machine/fcode.h>
     80 include <machine/mon.h>
     81 include <machine/pcb.h>
     82 include <machine/pmap.h>
     83 include <machine/psl.h>
     84 include <machine/pte.h>
     85 include <machine/vmparam.h>
     86 
     87 include <sun3/sun3/buserr.h>
     88 include <sun3/sun3/cache.h>
     89 
     90 include <sun3/sun3x/enable.h>
     91 
     92 # XXX: for copy.s
     93 define	M68030			1
     94 
     95 # for m68k_intr.c / m68k_intr_stubs.s
     96 define	__HAVE_M68K_INTR_VECTORED	1
     97 
     98 # bus error stuff XXX
     99 # define	BUSERR_REG			BUSERR_REG
    100 # define	BUSERR_MMU			BUSERR_MMU
    101 
    102 # 68k isms
    103 define	PSL_LOWIPL			PSL_LOWIPL
    104 define	PSL_HIGHIPL			PSL_HIGHIPL
    105 define	PSL_USER			PSL_USER
    106 define	PSL_S				PSL_S
    107 define	PSL_TS				PSL_T | PSL_S
    108 define	FC_CONTROL			FC_CONTROL
    109 define	FC_SUPERD			FC_SUPERD
    110 define	FC_USERD			FC_USERD
    111 define	IC_CLEAR			IC_CLEAR
    112 define	DC_CLEAR			DC_CLEAR
    113 define	CACHE_CLR			CACHE_CLR
    114 
    115 # sun3 memory map
    116 define	USRSTACK3X			USRSTACK3X
    117 define	SUN3X_MONSTART			SUN3X_MONSTART
    118 define	SUN3X_PROM_BASE			SUN3X_PROM_BASE
    119 define	SUN3X_MONEND			SUN3X_MONEND
    120 
    121 # kernel-isms
    122 define	KERNBASE3X			KERNBASE3X
    123 define	USPACE				USPACE
    124 define	PAGE_SIZE			PAGE_SIZE
    125 
    126 # system calls
    127 define	SYS_exit			SYS_exit
    128 define	SYS_compat_16___sigreturn14	SYS_compat_16___sigreturn14
    129 define	SYS_compat_13_sigreturn13	SYS_compat_13_sigreturn13
    130 
    131 # errno-isms
    132 define	EFAULT				EFAULT
    133 define	ENAMETOOLONG			ENAMETOOLONG
    134 
    135 # trap types: locore.s includes trap.h
    136 
    137 #
    138 # unix structure-isms
    139 #
    140 
    141 # lwp & proc fields and values
    142 define	L_PCB			offsetof(struct lwp, l_addr)
    143 define	L_PROC			offsetof(struct lwp, l_proc)
    144 define	L_MD_REGS		offsetof(struct lwp, l_md.md_regs)
    145 define	L_MD_FLAGS		offsetof(struct lwp, l_md.md_flags)
    146 define	P_FLAG			offsetof(struct proc, p_flag)
    147 define	P_RASLIST		offsetof(struct proc, p_raslist)
    148 define	P_VMSPACE		offsetof(struct proc, p_vmspace)
    149 
    150 # XXX: HP-UX trace bit?
    151 
    152 # VM/pmap structure fields
    153 define	VM_PMAP			offsetof(struct vmspace, vm_map.pmap)
    154 define	PM_A_PHYS		offsetof(struct pmap, pm_a_phys)
    155 define	PM_A_TMGR		offsetof(struct pmap, pm_a_tmgr)
    156 
    157 # pcb offsets
    158 define	PCB_FLAGS		offsetof(struct pcb, pcb_flags)
    159 define	PCB_PS			offsetof(struct pcb, pcb_ps)
    160 define	PCB_USP			offsetof(struct pcb, pcb_usp)
    161 define	PCB_REGS		offsetof(struct pcb, pcb_regs[0])
    162 define	PCB_ONFAULT		offsetof(struct pcb, pcb_onfault)
    163 define	PCB_FPCTX		offsetof(struct pcb, pcb_fpregs)
    164 define	SIZEOF_PCB		sizeof(struct pcb)
    165 
    166 # frame offsets
    167 define 	TF_PC			offsetof(struct frame, f_pc)
    168 
    169 # exception frame offset/sizes
    170 define	FR_SP			offsetof(struct trapframe, tf_regs[15])
    171 define	FR_ADJ			offsetof(struct trapframe, tf_stackadj)
    172 define	FR_HW			offsetof(struct trapframe, tf_sr)
    173 define	FR_SIZE			sizeof(struct trapframe)
    174 
    175 # FP frame offsets
    176 define	FPF_REGS		offsetof(struct fpframe, fpf_regs[0])
    177 define	FPF_FPCR		offsetof(struct fpframe, fpf_fpcr)
    178