xref: /netbsd-src/sys/arch/powerpc/oea/genassym.cf (revision 2d48ac808c43ea6701ba8f33cfc3645685301f79)
1#	$NetBSD: genassym.cf,v 1.14 2008/02/23 19:34:53 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
34include "opt_ppcarch.h"
35
36quote #define __MUTEX_PRIVATE
37quote #define __RWLOCK_PRIVATE
38
39include <sys/param.h>
40include <sys/time.h>
41include <sys/mutex.h>
42include <sys/rwlock.h>
43include <sys/proc.h>
44
45include <uvm/uvm_extern.h>
46
47include <machine/pcb.h>
48include <machine/pmap.h>
49
50include <powerpc/cpu.h>
51include <powerpc/oea/cpufeat.h>
52
53define	FRAMELEN	FRAMELEN
54define	FRAME_0		offsetof(struct trapframe, fixreg[0])
55define	FRAME_1		offsetof(struct trapframe, fixreg[1])
56define	FRAME_2		offsetof(struct trapframe, fixreg[2])
57define	FRAME_3		offsetof(struct trapframe, fixreg[3])
58define	FRAME_4		offsetof(struct trapframe, fixreg[4])
59define	FRAME_5		offsetof(struct trapframe, fixreg[5])
60define	FRAME_6		offsetof(struct trapframe, fixreg[6])
61define	FRAME_7		offsetof(struct trapframe, fixreg[7])
62define	FRAME_8		offsetof(struct trapframe, fixreg[8])
63define	FRAME_9		offsetof(struct trapframe, fixreg[9])
64define	FRAME_10	offsetof(struct trapframe, fixreg[10])
65define	FRAME_11	offsetof(struct trapframe, fixreg[11])
66define	FRAME_12	offsetof(struct trapframe, fixreg[12])
67define	FRAME_13	offsetof(struct trapframe, fixreg[13])
68define	FRAME_14	offsetof(struct trapframe, fixreg[14])
69define	FRAME_15	offsetof(struct trapframe, fixreg[15])
70define	FRAME_16	offsetof(struct trapframe, fixreg[16])
71define	FRAME_17	offsetof(struct trapframe, fixreg[17])
72define	FRAME_18	offsetof(struct trapframe, fixreg[18])
73define	FRAME_19	offsetof(struct trapframe, fixreg[19])
74define	FRAME_20	offsetof(struct trapframe, fixreg[20])
75define	FRAME_21	offsetof(struct trapframe, fixreg[21])
76define	FRAME_22	offsetof(struct trapframe, fixreg[22])
77define	FRAME_23	offsetof(struct trapframe, fixreg[23])
78define	FRAME_24	offsetof(struct trapframe, fixreg[24])
79define	FRAME_25	offsetof(struct trapframe, fixreg[25])
80define	FRAME_26	offsetof(struct trapframe, fixreg[26])
81define	FRAME_27	offsetof(struct trapframe, fixreg[27])
82define	FRAME_28	offsetof(struct trapframe, fixreg[28])
83define	FRAME_29	offsetof(struct trapframe, fixreg[29])
84define	FRAME_30	offsetof(struct trapframe, fixreg[30])
85define	FRAME_31	offsetof(struct trapframe, fixreg[31])
86define	FRAME_LR	offsetof(struct trapframe, lr)
87define	FRAME_CR	offsetof(struct trapframe, cr)
88define	FRAME_CTR	offsetof(struct trapframe, ctr)
89define	FRAME_XER	offsetof(struct trapframe, xer)
90define	FRAME_SRR0	offsetof(struct trapframe, srr0)
91define	FRAME_SRR1	offsetof(struct trapframe, srr1)
92define	FRAME_DAR	offsetof(struct trapframe, dar)
93define	FRAME_DSISR	offsetof(struct trapframe, dsisr)
94define	FRAME_EXC	offsetof(struct trapframe, exc)
95define	FRAME_VRSAVE	offsetof(struct trapframe, tf_xtra[TF_VRSAVE])
96define	FRAME_MQ	offsetof(struct trapframe, tf_xtra[TF_MQ])
97
98define	IFRAMELEN		IFRAMELEN
99define	IFRAME_R1		offsetof(struct intrframe, r1)
100define	IFRAME_SRR1		offsetof(struct intrframe, srr1)
101define	IFRAME_SRR0		offsetof(struct intrframe, srr0)
102define	IFRAME_PRI		offsetof(struct intrframe, pri)
103define	IFRAME_INTR_DEPTH	offsetof(struct intrframe, intrdepth)
104define	IFRAME_PID		offsetof(struct intrframe, pid)
105define	IFRAME_CTR		offsetof(struct intrframe, ctr)
106define	IFRAME_XER		offsetof(struct intrframe, xer)
107define	IFRAME_CR		offsetof(struct intrframe, cr)
108define	IFRAME_LR		offsetof(struct intrframe, lr)
109define	IFRAME_R12		offsetof(struct intrframe, r12)
110define	IFRAME_R11		offsetof(struct intrframe, r11)
111define	IFRAME_R10		offsetof(struct intrframe, r10)
112define	IFRAME_R9		offsetof(struct intrframe, r9)
113define	IFRAME_R8		offsetof(struct intrframe, r8)
114define	IFRAME_R7		offsetof(struct intrframe, r7)
115define	IFRAME_R6		offsetof(struct intrframe, r6)
116define	IFRAME_R5		offsetof(struct intrframe, r5)
117define	IFRAME_R4		offsetof(struct intrframe, r4)
118define	IFRAME_R3		offsetof(struct intrframe, r3)
119define	IFRAME_R0		offsetof(struct intrframe, r0)
120
121ifdef PPC_OEA64
122define	PM_STEG		offsetof(struct pmap, pm_steg_table)
123else
124define	PM_SR		offsetof(struct pmap, pm_sr[0])
125define	PM_USRSR	offsetof(struct pmap, pm_sr[USER_SR])
126define	PM_KERNELSR	offsetof(struct pmap, pm_sr[KERNEL_SR])
127endif
128
129define	CALLFRAMELEN	CALLFRAMELEN
130define	CFRAME_SP	offsetof(struct callframe, sp)
131define	CFRAME_LR	offsetof(struct callframe, lr)
132define	CFRAME_R30	offsetof(struct callframe, r30)
133define	CFRAME_R31	offsetof(struct callframe, r31)
134
135define	SFRAMELEN	SFRAMELEN
136define	SFRAME_SP	offsetof(struct switchframe, sp)
137define	SFRAME_LR	offsetof(struct switchframe, lr)
138define	SFRAME_USER_SR	offsetof(struct switchframe, user_sr)
139define	SFRAME_CR	offsetof(struct switchframe, cr)
140define	SFRAME_R2	offsetof(struct switchframe, fixreg2)
141define	SFRAME_R13	offsetof(struct switchframe, fixreg[0])
142define	SFRAME_R14	offsetof(struct switchframe, fixreg[1])
143define	SFRAME_R15	offsetof(struct switchframe, fixreg[2])
144define	SFRAME_R16	offsetof(struct switchframe, fixreg[3])
145define	SFRAME_R17	offsetof(struct switchframe, fixreg[4])
146define	SFRAME_R18	offsetof(struct switchframe, fixreg[5])
147define	SFRAME_R19	offsetof(struct switchframe, fixreg[6])
148define	SFRAME_R20	offsetof(struct switchframe, fixreg[7])
149define	SFRAME_R21	offsetof(struct switchframe, fixreg[8])
150define	SFRAME_R22	offsetof(struct switchframe, fixreg[9])
151define	SFRAME_R23	offsetof(struct switchframe, fixreg[10])
152define	SFRAME_R24	offsetof(struct switchframe, fixreg[11])
153define	SFRAME_R25	offsetof(struct switchframe, fixreg[12])
154define	SFRAME_R26	offsetof(struct switchframe, fixreg[13])
155define	SFRAME_R27	offsetof(struct switchframe, fixreg[14])
156define	SFRAME_R28	offsetof(struct switchframe, fixreg[15])
157define	SFRAME_R29	offsetof(struct switchframe, fixreg[16])
158define	SFRAME_R30	offsetof(struct switchframe, fixreg[17])
159define	SFRAME_R31	offsetof(struct switchframe, fixreg[18])
160
161define	PCB_PM		offsetof(struct pcb, pcb_pm)
162define	PCB_SP		offsetof(struct pcb, pcb_sp)
163define	PCB_FAULT	offsetof(struct pcb, pcb_onfault)
164
165define	L_ADDR		offsetof(struct lwp, l_addr)
166define	L_STAT		offsetof(struct lwp, l_stat)
167define	L_CPU		offsetof(struct lwp, l_cpu)
168define	L_PRIORITY	offsetof(struct lwp, l_priority)
169define	L_PROC		offsetof(struct lwp, l_proc)
170
171define	LSRUN		LSRUN
172define	LSONPROC	LSONPROC
173define	P_MD_SYSCALL	offsetof(struct proc, p_md.md_syscall)
174
175define	CI_SIZE		sizeof(struct cpu_info)
176define	CI_CURLWP	offsetof(struct cpu_info, ci_curlwp)
177define	CI_CURPCB	offsetof(struct cpu_info, ci_curpcb)
178define	CI_CURPM	offsetof(struct cpu_info, ci_curpm)
179define	CI_ASTPENDING	offsetof(struct cpu_info, ci_astpending)
180define	CI_WANT_RESCHED	offsetof(struct cpu_info, ci_want_resched)
181define	CI_CPL		offsetof(struct cpu_info, ci_cpl)
182define	CI_INTRDEPTH	offsetof(struct cpu_info, ci_intrdepth)
183define	CI_INTSTK	offsetof(struct cpu_info, ci_intstk)
184define	CI_TEMPSAVE	offsetof(struct cpu_info, ci_tempsave)
185define	CI_DDBSAVE	offsetof(struct cpu_info, ci_ddbsave)
186define	CI_IPKDBSAVE	offsetof(struct cpu_info, ci_ipkdbsave)
187define	CI_DISISAVE	offsetof(struct cpu_info, ci_disisave)
188define	CI_IDLESPIN	offsetof(struct cpu_info, ci_idlespin)
189
190define	CPUSAVE_R28	CPUSAVE_R28*sizeof(register_t)
191define	CPUSAVE_R29	CPUSAVE_R29*sizeof(register_t)
192define	CPUSAVE_R30	CPUSAVE_R30*sizeof(register_t)
193define	CPUSAVE_R31	CPUSAVE_R31*sizeof(register_t)
194define	CPUSAVE_DAR	CPUSAVE_DAR*sizeof(register_t)
195define	CPUSAVE_DSISR	CPUSAVE_DSISR*sizeof(register_t)
196define	CPUSAVE_SRR0	CPUSAVE_SRR0*sizeof(register_t)
197define	CPUSAVE_SRR1	CPUSAVE_SRR1*sizeof(register_t)
198
199define	FB_PC		offsetof(struct faultbuf, fb_pc)
200define	FB_SP		offsetof(struct faultbuf, fb_sp)
201define	FB_R2		offsetof(struct faultbuf, fb_r2)
202define	FB_CR		offsetof(struct faultbuf, fb_cr)
203define	FB_R13		offsetof(struct faultbuf, fb_fixreg[0])
204define	FB_R14		offsetof(struct faultbuf, fb_fixreg[1])
205define	FB_R15		offsetof(struct faultbuf, fb_fixreg[2])
206define	FB_R16		offsetof(struct faultbuf, fb_fixreg[3])
207define	FB_R17		offsetof(struct faultbuf, fb_fixreg[4])
208define	FB_R18		offsetof(struct faultbuf, fb_fixreg[5])
209define	FB_R19		offsetof(struct faultbuf, fb_fixreg[6])
210define	FB_R20		offsetof(struct faultbuf, fb_fixreg[7])
211define	FB_R21		offsetof(struct faultbuf, fb_fixreg[8])
212define	FB_R22		offsetof(struct faultbuf, fb_fixreg[9])
213define	FB_R23		offsetof(struct faultbuf, fb_fixreg[10])
214define	FB_R24		offsetof(struct faultbuf, fb_fixreg[11])
215define	FB_R25		offsetof(struct faultbuf, fb_fixreg[12])
216define	FB_R26		offsetof(struct faultbuf, fb_fixreg[13])
217define	FB_R27		offsetof(struct faultbuf, fb_fixreg[14])
218define	FB_R28		offsetof(struct faultbuf, fb_fixreg[15])
219define	FB_R29		offsetof(struct faultbuf, fb_fixreg[16])
220define	FB_R30		offsetof(struct faultbuf, fb_fixreg[17])
221define	FB_R31		offsetof(struct faultbuf, fb_fixreg[18])
222
223define	CACHELINESIZE	CACHELINESIZE
224
225define	CPU_CI		offsetof(struct cpu_info, ci_ci)
226
227define	OEACPU_64	OEACPU_64
228define	OEACPU_64_BRIDGE	OEACPU_64_BRIDGE
229define	OEACPU_NOBAT	OEACPU_NOBAT
230define	OEACPU_HIGHBAT	OEACPU_HIGHBAT
231define	OEACPU_601	OEACPU_601
232define	OEACPU_HIGHSPRG	OEACPU_HIGHSPRG
233define	OEACPU_ALTIVEC	OEACPU_ALTIVEC
234
235ifdef	__HAVE_MUTEX_STUBS
236define	__HAVE_MUTEX_STUBS	__HAVE_MUTEX_STUBS
237endif
238ifdef	__HAVE_MUTEX_SPIN_STUBS
239define	__HAVE_MUTEX_SPIN_STUBS	__HAVE_MUTEX_SPIN_STUBS
240endif
241define	MTX_OWNER	offsetof(struct kmutex, mtx_owner)
242define	MTX_LOCK	offsetof(struct kmutex, mtx_lock)
243define	MTX_IPL		offsetof(struct kmutex, mtx_ipl)
244
245ifdef	__HAVE_RW_STUBS
246define	__HAVE_RW_STUBS	__HAVE_RW_STUBS
247endif
248define	RW_OWNER	offsetof(struct krwlock, rw_owner)
249define	RW_WRITE_LOCKED	RW_WRITE_LOCKED
250define	RW_READ_INCR	RW_READ_INCR
251define	RW_READER	RW_READER
252