genassym.cf revision 1.18 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