genassym.cf revision 1.7 1 # $NetBSD: genassym.cf,v 1.7 2003/11/21 18:07:29 matt Exp $
2
3 #
4 # Copyright (C) 1995, 1996 Wolfgang Solfrank.
5 # Copyright (C) 1995, 1996 TooLs GmbH.
6 # All rights reserved.
7 #
8 # Redistribution and use in source and binary forms, with or without
9 # modification, are permitted provided that the following conditions
10 # are met:
11 # 1. Redistributions of source code must retain the above copyright
12 # notice, this list of conditions and the following disclaimer.
13 # 2. Redistributions in binary form must reproduce the above copyright
14 # notice, this list of conditions and the following disclaimer in the
15 # documentation and/or other materials provided with the distribution.
16 # 3. All advertising materials mentioning features or use of this software
17 # must display the following acknowledgement:
18 # This product includes software developed by TooLs GmbH.
19 # 4. The name of TooLs GmbH may not be used to endorse or promote products
20 # derived from this software without specific prior written permission.
21 #
22 # THIS SOFTWARE IS PROVIDED BY TOOLS GMBH ``AS IS'' AND ANY EXPRESS OR
23 # IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
24 # OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
25 # IN NO EVENT SHALL TOOLS GMBH BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26 # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
27 # PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
28 # OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
29 # WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
30 # OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
31 # ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 #
33
34 include "opt_ppcarch.h"
35
36 include <sys/param.h>
37 include <sys/time.h>
38 include <sys/proc.h>
39
40 include <uvm/uvm_extern.h>
41
42 include <machine/pcb.h>
43 include <machine/pmap.h>
44
45 include <powerpc/cpu.h>
46
47 define FRAMELEN FRAMELEN
48 define FRAME_0 offsetof(struct trapframe, fixreg[0])
49 define FRAME_1 offsetof(struct trapframe, fixreg[1])
50 define FRAME_2 offsetof(struct trapframe, fixreg[2])
51 define FRAME_3 offsetof(struct trapframe, fixreg[3])
52 define FRAME_4 offsetof(struct trapframe, fixreg[4])
53 define FRAME_5 offsetof(struct trapframe, fixreg[5])
54 define FRAME_6 offsetof(struct trapframe, fixreg[6])
55 define FRAME_7 offsetof(struct trapframe, fixreg[7])
56 define FRAME_8 offsetof(struct trapframe, fixreg[8])
57 define FRAME_9 offsetof(struct trapframe, fixreg[9])
58 define FRAME_10 offsetof(struct trapframe, fixreg[10])
59 define FRAME_11 offsetof(struct trapframe, fixreg[11])
60 define FRAME_12 offsetof(struct trapframe, fixreg[12])
61 define FRAME_13 offsetof(struct trapframe, fixreg[13])
62 define FRAME_14 offsetof(struct trapframe, fixreg[14])
63 define FRAME_15 offsetof(struct trapframe, fixreg[15])
64 define FRAME_16 offsetof(struct trapframe, fixreg[16])
65 define FRAME_17 offsetof(struct trapframe, fixreg[17])
66 define FRAME_18 offsetof(struct trapframe, fixreg[18])
67 define FRAME_19 offsetof(struct trapframe, fixreg[19])
68 define FRAME_20 offsetof(struct trapframe, fixreg[20])
69 define FRAME_21 offsetof(struct trapframe, fixreg[21])
70 define FRAME_22 offsetof(struct trapframe, fixreg[22])
71 define FRAME_23 offsetof(struct trapframe, fixreg[23])
72 define FRAME_24 offsetof(struct trapframe, fixreg[24])
73 define FRAME_25 offsetof(struct trapframe, fixreg[25])
74 define FRAME_26 offsetof(struct trapframe, fixreg[26])
75 define FRAME_27 offsetof(struct trapframe, fixreg[27])
76 define FRAME_28 offsetof(struct trapframe, fixreg[28])
77 define FRAME_29 offsetof(struct trapframe, fixreg[29])
78 define FRAME_30 offsetof(struct trapframe, fixreg[30])
79 define FRAME_31 offsetof(struct trapframe, fixreg[31])
80 define FRAME_LR offsetof(struct trapframe, lr)
81 define FRAME_CR offsetof(struct trapframe, cr)
82 define FRAME_CTR offsetof(struct trapframe, ctr)
83 define FRAME_XER offsetof(struct trapframe, xer)
84 define FRAME_SRR0 offsetof(struct trapframe, srr0)
85 define FRAME_SRR1 offsetof(struct trapframe, srr1)
86 define FRAME_DAR offsetof(struct trapframe, dar)
87 define FRAME_DSISR offsetof(struct trapframe, dsisr)
88 define FRAME_EXC offsetof(struct trapframe, exc)
89 define FRAME_VRSAVE offsetof(struct trapframe, tf_xtra[TF_VRSAVE])
90 define FRAME_MQ offsetof(struct trapframe, tf_xtra[TF_MQ])
91
92 define IFRAMELEN IFRAMELEN
93 define IFRAME_R1 offsetof(struct intrframe, r1)
94 define IFRAME_SRR1 offsetof(struct intrframe, srr1)
95 define IFRAME_SRR0 offsetof(struct intrframe, srr0)
96 define IFRAME_PRI offsetof(struct intrframe, pri)
97 define IFRAME_INTR_DEPTH offsetof(struct intrframe, intrdepth)
98 define IFRAME_PID offsetof(struct intrframe, pid)
99 define IFRAME_CTR offsetof(struct intrframe, ctr)
100 define IFRAME_XER offsetof(struct intrframe, xer)
101 define IFRAME_CR offsetof(struct intrframe, cr)
102 define IFRAME_LR offsetof(struct intrframe, lr)
103 define IFRAME_R12 offsetof(struct intrframe, r12)
104 define IFRAME_R11 offsetof(struct intrframe, r11)
105 define IFRAME_R10 offsetof(struct intrframe, r10)
106 define IFRAME_R9 offsetof(struct intrframe, r9)
107 define IFRAME_R8 offsetof(struct intrframe, r8)
108 define IFRAME_R7 offsetof(struct intrframe, r7)
109 define IFRAME_R6 offsetof(struct intrframe, r6)
110 define IFRAME_R5 offsetof(struct intrframe, r5)
111 define IFRAME_R4 offsetof(struct intrframe, r4)
112 define IFRAME_R3 offsetof(struct intrframe, r3)
113 define IFRAME_R0 offsetof(struct intrframe, r0)
114
115 ifdef PPC_OEA64
116 define PM_STEG offsetof(struct pmap, pm_steg_table)
117 else
118 define PM_SR offsetof(struct pmap, pm_sr[0])
119 define PM_USRSR offsetof(struct pmap, pm_sr[USER_SR])
120 define PM_KERNELSR offsetof(struct pmap, pm_sr[KERNEL_SR])
121 endif
122
123 define CALLFRAMELEN CALLFRAMELEN
124 define CFRAME_SP offsetof(struct callframe, sp)
125 define CFRAME_LR offsetof(struct callframe, lr)
126 define CFRAME_R30 offsetof(struct callframe, r30)
127 define CFRAME_R31 offsetof(struct callframe, r31)
128
129 define SFRAMELEN SFRAMELEN
130 define SFRAME_SP offsetof(struct switchframe, sp)
131 define SFRAME_LR offsetof(struct switchframe, lr)
132 define SFRAME_USER_SR offsetof(struct switchframe, user_sr)
133 define SFRAME_CR offsetof(struct switchframe, cr)
134 define SFRAME_R2 offsetof(struct switchframe, fixreg2)
135 define SFRAME_R13 offsetof(struct switchframe, fixreg[0])
136 define SFRAME_R14 offsetof(struct switchframe, fixreg[1])
137 define SFRAME_R15 offsetof(struct switchframe, fixreg[2])
138 define SFRAME_R16 offsetof(struct switchframe, fixreg[3])
139 define SFRAME_R17 offsetof(struct switchframe, fixreg[4])
140 define SFRAME_R18 offsetof(struct switchframe, fixreg[5])
141 define SFRAME_R19 offsetof(struct switchframe, fixreg[6])
142 define SFRAME_R20 offsetof(struct switchframe, fixreg[7])
143 define SFRAME_R21 offsetof(struct switchframe, fixreg[8])
144 define SFRAME_R22 offsetof(struct switchframe, fixreg[9])
145 define SFRAME_R23 offsetof(struct switchframe, fixreg[10])
146 define SFRAME_R24 offsetof(struct switchframe, fixreg[11])
147 define SFRAME_R25 offsetof(struct switchframe, fixreg[12])
148 define SFRAME_R26 offsetof(struct switchframe, fixreg[13])
149 define SFRAME_R27 offsetof(struct switchframe, fixreg[14])
150 define SFRAME_R28 offsetof(struct switchframe, fixreg[15])
151 define SFRAME_R29 offsetof(struct switchframe, fixreg[16])
152 define SFRAME_R30 offsetof(struct switchframe, fixreg[17])
153 define SFRAME_R31 offsetof(struct switchframe, fixreg[18])
154
155 define PCB_PM offsetof(struct pcb, pcb_pm)
156 define PCB_SP offsetof(struct pcb, pcb_sp)
157 define PCB_FAULT offsetof(struct pcb, pcb_onfault)
158
159 define L_FORW offsetof(struct lwp, l_forw)
160 define L_BACK offsetof(struct lwp, l_back)
161 define L_ADDR offsetof(struct lwp, l_addr)
162 define L_STAT offsetof(struct lwp, l_stat)
163 define L_CPU offsetof(struct lwp, l_cpu)
164 define L_PRIORITY offsetof(struct lwp, l_priority)
165 define L_PROC offsetof(struct lwp, l_proc)
166
167 define LSONPROC LSONPROC
168 define P_MD_SYSCALL offsetof(struct proc, p_md.md_syscall)
169
170 define CI_SIZE sizeof(struct cpu_info)
171 define CI_CURLWP offsetof(struct cpu_info, ci_curlwp)
172 define CI_CURPCB offsetof(struct cpu_info, ci_curpcb)
173 define CI_CURPM offsetof(struct cpu_info, ci_curpm)
174 define CI_IDLE_PCB offsetof(struct cpu_info, ci_idle_pcb)
175 define CI_ASTPENDING offsetof(struct cpu_info, ci_astpending)
176 define CI_WANT_RESCHED offsetof(struct cpu_info, ci_want_resched)
177 define CI_CPL offsetof(struct cpu_info, ci_cpl)
178 define CI_INTRDEPTH offsetof(struct cpu_info, ci_intrdepth)
179 define CI_INTSTK offsetof(struct cpu_info, ci_intstk)
180 define CI_TEMPSAVE offsetof(struct cpu_info, ci_tempsave)
181 define CI_DDBSAVE offsetof(struct cpu_info, ci_ddbsave)
182 define CI_IPKDBSAVE offsetof(struct cpu_info, ci_ipkdbsave)
183 define CI_DISISAVE offsetof(struct cpu_info, ci_disisave)
184
185 define CPUSAVE_R28 CPUSAVE_R28*sizeof(register_t)
186 define CPUSAVE_R29 CPUSAVE_R29*sizeof(register_t)
187 define CPUSAVE_R30 CPUSAVE_R30*sizeof(register_t)
188 define CPUSAVE_R31 CPUSAVE_R31*sizeof(register_t)
189 define CPUSAVE_DAR CPUSAVE_DAR*sizeof(register_t)
190 define CPUSAVE_DSISR CPUSAVE_DSISR*sizeof(register_t)
191 define CPUSAVE_SRR0 CPUSAVE_SRR0*sizeof(register_t)
192 define CPUSAVE_SRR1 CPUSAVE_SRR1*sizeof(register_t)
193
194 define FB_PC offsetof(struct faultbuf, fb_pc)
195 define FB_SP offsetof(struct faultbuf, fb_sp)
196 define FB_R2 offsetof(struct faultbuf, fb_r2)
197 define FB_CR offsetof(struct faultbuf, fb_cr)
198 define FB_R13 offsetof(struct faultbuf, fb_fixreg[0])
199 define FB_R14 offsetof(struct faultbuf, fb_fixreg[1])
200 define FB_R15 offsetof(struct faultbuf, fb_fixreg[2])
201 define FB_R16 offsetof(struct faultbuf, fb_fixreg[3])
202 define FB_R17 offsetof(struct faultbuf, fb_fixreg[4])
203 define FB_R18 offsetof(struct faultbuf, fb_fixreg[5])
204 define FB_R19 offsetof(struct faultbuf, fb_fixreg[6])
205 define FB_R20 offsetof(struct faultbuf, fb_fixreg[7])
206 define FB_R21 offsetof(struct faultbuf, fb_fixreg[8])
207 define FB_R22 offsetof(struct faultbuf, fb_fixreg[9])
208 define FB_R23 offsetof(struct faultbuf, fb_fixreg[10])
209 define FB_R24 offsetof(struct faultbuf, fb_fixreg[11])
210 define FB_R25 offsetof(struct faultbuf, fb_fixreg[12])
211 define FB_R26 offsetof(struct faultbuf, fb_fixreg[13])
212 define FB_R27 offsetof(struct faultbuf, fb_fixreg[14])
213 define FB_R28 offsetof(struct faultbuf, fb_fixreg[15])
214 define FB_R29 offsetof(struct faultbuf, fb_fixreg[16])
215 define FB_R30 offsetof(struct faultbuf, fb_fixreg[17])
216 define FB_R31 offsetof(struct faultbuf, fb_fixreg[18])
217
218 define CACHELINESIZE CACHELINESIZE
219
220 define CPU_CI offsetof(struct cpu_info, ci_ci)
221