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