Home | History | Annotate | Line # | Download | only in sun3x
genassym.cf revision 1.17
      1 #	$NetBSD: genassym.cf,v 1.17 2023/12/27 17:35:37 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 # bus error stuff XXX
     96 # define	BUSERR_REG			BUSERR_REG
     97 # define	BUSERR_MMU			BUSERR_MMU
     98 
     99 # 68k isms
    100 define	PSL_LOWIPL			PSL_LOWIPL
    101 define	PSL_HIGHIPL			PSL_HIGHIPL
    102 define	PSL_USER			PSL_USER
    103 define	PSL_S				PSL_S
    104 define	PSL_TS				PSL_T | PSL_S
    105 define	FC_CONTROL			FC_CONTROL
    106 define	FC_SUPERD			FC_SUPERD
    107 define	FC_USERD			FC_USERD
    108 define	IC_CLEAR			IC_CLEAR
    109 define	DC_CLEAR			DC_CLEAR
    110 define	CACHE_CLR			CACHE_CLR
    111 
    112 # sun3 memory map
    113 define	USRSTACK3X			USRSTACK3X
    114 define	SUN3X_MONSTART			SUN3X_MONSTART
    115 define	SUN3X_PROM_BASE			SUN3X_PROM_BASE
    116 define	SUN3X_MONEND			SUN3X_MONEND
    117 
    118 # kernel-isms
    119 define	KERNBASE3X			KERNBASE3X
    120 define	USPACE				USPACE
    121 define	PAGE_SIZE			PAGE_SIZE
    122 
    123 # system calls
    124 define	SYS_exit			SYS_exit
    125 define	SYS_compat_16___sigreturn14	SYS_compat_16___sigreturn14
    126 define	SYS_compat_13_sigreturn13	SYS_compat_13_sigreturn13
    127 
    128 # errno-isms
    129 define	EFAULT				EFAULT
    130 define	ENAMETOOLONG			ENAMETOOLONG
    131 
    132 # trap types: locore.s includes trap.h
    133 
    134 #
    135 # unix structure-isms
    136 #
    137 
    138 # lwp & proc fields and values
    139 define	L_PCB			offsetof(struct lwp, l_addr)
    140 define	L_PROC			offsetof(struct lwp, l_proc)
    141 define	L_MD_REGS		offsetof(struct lwp, l_md.md_regs)
    142 define	L_MD_FLAGS		offsetof(struct lwp, l_md.md_flags)
    143 define	P_FLAG			offsetof(struct proc, p_flag)
    144 define	P_RASLIST		offsetof(struct proc, p_raslist)
    145 define	P_VMSPACE		offsetof(struct proc, p_vmspace)
    146 
    147 # XXX: HP-UX trace bit?
    148 
    149 # VM/pmap structure fields
    150 define	VM_PMAP			offsetof(struct vmspace, vm_map.pmap)
    151 define	PM_A_PHYS		offsetof(struct pmap, pm_a_phys)
    152 define	PM_A_TMGR		offsetof(struct pmap, pm_a_tmgr)
    153 
    154 # pcb offsets
    155 define	PCB_FLAGS		offsetof(struct pcb, pcb_flags)
    156 define	PCB_PS			offsetof(struct pcb, pcb_ps)
    157 define	PCB_USP			offsetof(struct pcb, pcb_usp)
    158 define	PCB_REGS		offsetof(struct pcb, pcb_regs[0])
    159 define	PCB_ONFAULT		offsetof(struct pcb, pcb_onfault)
    160 define	PCB_FPCTX		offsetof(struct pcb, pcb_fpregs)
    161 define	SIZEOF_PCB		sizeof(struct pcb)
    162 
    163 # frame offsets
    164 define 	TF_PC			offsetof(struct frame, f_pc)
    165 
    166 # exception frame offset/sizes
    167 define	FR_SP			offsetof(struct trapframe, tf_regs[15])
    168 define	FR_ADJ			offsetof(struct trapframe, tf_stackadj)
    169 define	FR_HW			offsetof(struct trapframe, tf_sr)
    170 define	FR_SIZE			sizeof(struct trapframe)
    171 
    172 # FP frame offsets
    173 define	FPF_REGS		offsetof(struct fpframe, fpf_regs[0])
    174 define	FPF_FPCR		offsetof(struct fpframe, fpf_fpcr)
    175