genassym.c revision 265972
1/*- 2 * Copyright (c) 1982, 1990 The Regents of the University of California. 3 * All rights reserved. 4 * 5 * This code is derived from software contributed to Berkeley by 6 * William Jolitz. 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 * 4. Neither the name of the University nor the names of its contributors 17 * may be used to endorse or promote products derived from this software 18 * without specific prior written permission. 19 * 20 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 21 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 22 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 23 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 24 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 25 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 26 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 27 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 28 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 29 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 30 * SUCH DAMAGE. 31 * 32 * from: @(#)genassym.c 5.11 (Berkeley) 5/10/91 33 * $FreeBSD: stable/10/sys/powerpc/powerpc/genassym.c 265972 2014-05-13 18:24:02Z ian $ 34 */ 35 36#include <sys/param.h> 37#include <sys/assym.h> 38#include <sys/errno.h> 39#include <sys/ktr.h> 40#include <sys/proc.h> 41#include <sys/queue.h> 42#include <sys/signal.h> 43#include <sys/smp.h> 44#include <sys/systm.h> 45#include <sys/ucontext.h> 46#include <sys/ucontext.h> 47#include <sys/vmmeter.h> 48 49#include <vm/vm.h> 50#include <vm/vm_param.h> 51#include <vm/pmap.h> 52#include <vm/vm_map.h> 53 54#include <machine/pcb.h> 55#include <machine/pmap.h> 56#include <machine/psl.h> 57#include <machine/sigframe.h> 58 59ASSYM(PC_CURTHREAD, offsetof(struct pcpu, pc_curthread)); 60ASSYM(PC_CURPCB, offsetof(struct pcpu, pc_curpcb)); 61ASSYM(PC_CURPMAP, offsetof(struct pcpu, pc_curpmap)); 62ASSYM(PC_TEMPSAVE, offsetof(struct pcpu, pc_tempsave)); 63ASSYM(PC_DISISAVE, offsetof(struct pcpu, pc_disisave)); 64ASSYM(PC_DBSAVE, offsetof(struct pcpu, pc_dbsave)); 65ASSYM(PC_RESTORE, offsetof(struct pcpu, pc_restore)); 66 67#if defined(BOOKE) 68ASSYM(PC_BOOKE_CRITSAVE, offsetof(struct pcpu, pc_booke_critsave)); 69ASSYM(PC_BOOKE_MCHKSAVE, offsetof(struct pcpu, pc_booke_mchksave)); 70ASSYM(PC_BOOKE_TLBSAVE, offsetof(struct pcpu, pc_booke_tlbsave)); 71ASSYM(PC_BOOKE_TLB_LEVEL, offsetof(struct pcpu, pc_booke_tlb_level)); 72ASSYM(PC_BOOKE_TLB_LOCK, offsetof(struct pcpu, pc_booke_tlb_lock)); 73#endif 74 75ASSYM(CPUSAVE_R27, CPUSAVE_R27*sizeof(register_t)); 76ASSYM(CPUSAVE_R28, CPUSAVE_R28*sizeof(register_t)); 77ASSYM(CPUSAVE_R29, CPUSAVE_R29*sizeof(register_t)); 78ASSYM(CPUSAVE_R30, CPUSAVE_R30*sizeof(register_t)); 79ASSYM(CPUSAVE_R31, CPUSAVE_R31*sizeof(register_t)); 80ASSYM(CPUSAVE_SRR0, CPUSAVE_SRR0*sizeof(register_t)); 81ASSYM(CPUSAVE_SRR1, CPUSAVE_SRR1*sizeof(register_t)); 82ASSYM(CPUSAVE_AIM_DAR, CPUSAVE_AIM_DAR*sizeof(register_t)); 83ASSYM(CPUSAVE_AIM_DSISR, CPUSAVE_AIM_DSISR*sizeof(register_t)); 84ASSYM(CPUSAVE_BOOKE_DEAR, CPUSAVE_BOOKE_DEAR*sizeof(register_t)); 85ASSYM(CPUSAVE_BOOKE_ESR, CPUSAVE_BOOKE_ESR*sizeof(register_t)); 86 87ASSYM(TLBSAVE_BOOKE_LR, TLBSAVE_BOOKE_LR*sizeof(register_t)); 88ASSYM(TLBSAVE_BOOKE_CR, TLBSAVE_BOOKE_CR*sizeof(register_t)); 89ASSYM(TLBSAVE_BOOKE_SRR0, TLBSAVE_BOOKE_SRR0*sizeof(register_t)); 90ASSYM(TLBSAVE_BOOKE_SRR1, TLBSAVE_BOOKE_SRR1*sizeof(register_t)); 91ASSYM(TLBSAVE_BOOKE_R20, TLBSAVE_BOOKE_R20*sizeof(register_t)); 92ASSYM(TLBSAVE_BOOKE_R21, TLBSAVE_BOOKE_R21*sizeof(register_t)); 93ASSYM(TLBSAVE_BOOKE_R22, TLBSAVE_BOOKE_R22*sizeof(register_t)); 94ASSYM(TLBSAVE_BOOKE_R23, TLBSAVE_BOOKE_R23*sizeof(register_t)); 95ASSYM(TLBSAVE_BOOKE_R24, TLBSAVE_BOOKE_R24*sizeof(register_t)); 96ASSYM(TLBSAVE_BOOKE_R25, TLBSAVE_BOOKE_R25*sizeof(register_t)); 97ASSYM(TLBSAVE_BOOKE_R26, TLBSAVE_BOOKE_R26*sizeof(register_t)); 98ASSYM(TLBSAVE_BOOKE_R27, TLBSAVE_BOOKE_R27*sizeof(register_t)); 99ASSYM(TLBSAVE_BOOKE_R28, TLBSAVE_BOOKE_R28*sizeof(register_t)); 100ASSYM(TLBSAVE_BOOKE_R29, TLBSAVE_BOOKE_R29*sizeof(register_t)); 101ASSYM(TLBSAVE_BOOKE_R30, TLBSAVE_BOOKE_R30*sizeof(register_t)); 102ASSYM(TLBSAVE_BOOKE_R31, TLBSAVE_BOOKE_R31*sizeof(register_t)); 103 104ASSYM(MTX_LOCK, offsetof(struct mtx, mtx_lock)); 105 106#if defined(AIM) 107ASSYM(USER_ADDR, USER_ADDR); 108#ifdef __powerpc64__ 109ASSYM(PC_KERNSLB, offsetof(struct pcpu, pc_slb)); 110ASSYM(PC_USERSLB, offsetof(struct pcpu, pc_userslb)); 111ASSYM(PC_SLBSAVE, offsetof(struct pcpu, pc_slbsave)); 112ASSYM(PC_SLBSTACK, offsetof(struct pcpu, pc_slbstack)); 113ASSYM(USER_SLB_SLOT, USER_SLB_SLOT); 114ASSYM(USER_SLB_SLBE, USER_SLB_SLBE); 115ASSYM(SEGMENT_MASK, SEGMENT_MASK); 116#else 117ASSYM(PM_SR, offsetof(struct pmap, pm_sr)); 118ASSYM(USER_SR, USER_SR); 119#endif 120#elif defined(BOOKE) 121ASSYM(PM_PDIR, offsetof(struct pmap, pm_pdir)); 122ASSYM(PTE_RPN, offsetof(struct pte, rpn)); 123ASSYM(PTE_FLAGS, offsetof(struct pte, flags)); 124#if defined(BOOKE_E500) 125ASSYM(TLB0_ENTRY_SIZE, sizeof(struct tlb_entry)); 126#endif 127#endif 128 129#ifdef __powerpc64__ 130ASSYM(FSP, 48); 131#else 132ASSYM(FSP, 8); 133#endif 134ASSYM(FRAMELEN, FRAMELEN); 135ASSYM(FRAME_0, offsetof(struct trapframe, fixreg[0])); 136ASSYM(FRAME_1, offsetof(struct trapframe, fixreg[1])); 137ASSYM(FRAME_2, offsetof(struct trapframe, fixreg[2])); 138ASSYM(FRAME_3, offsetof(struct trapframe, fixreg[3])); 139ASSYM(FRAME_4, offsetof(struct trapframe, fixreg[4])); 140ASSYM(FRAME_5, offsetof(struct trapframe, fixreg[5])); 141ASSYM(FRAME_6, offsetof(struct trapframe, fixreg[6])); 142ASSYM(FRAME_7, offsetof(struct trapframe, fixreg[7])); 143ASSYM(FRAME_8, offsetof(struct trapframe, fixreg[8])); 144ASSYM(FRAME_9, offsetof(struct trapframe, fixreg[9])); 145ASSYM(FRAME_10, offsetof(struct trapframe, fixreg[10])); 146ASSYM(FRAME_11, offsetof(struct trapframe, fixreg[11])); 147ASSYM(FRAME_12, offsetof(struct trapframe, fixreg[12])); 148ASSYM(FRAME_13, offsetof(struct trapframe, fixreg[13])); 149ASSYM(FRAME_14, offsetof(struct trapframe, fixreg[14])); 150ASSYM(FRAME_15, offsetof(struct trapframe, fixreg[15])); 151ASSYM(FRAME_16, offsetof(struct trapframe, fixreg[16])); 152ASSYM(FRAME_17, offsetof(struct trapframe, fixreg[17])); 153ASSYM(FRAME_18, offsetof(struct trapframe, fixreg[18])); 154ASSYM(FRAME_19, offsetof(struct trapframe, fixreg[19])); 155ASSYM(FRAME_20, offsetof(struct trapframe, fixreg[20])); 156ASSYM(FRAME_21, offsetof(struct trapframe, fixreg[21])); 157ASSYM(FRAME_22, offsetof(struct trapframe, fixreg[22])); 158ASSYM(FRAME_23, offsetof(struct trapframe, fixreg[23])); 159ASSYM(FRAME_24, offsetof(struct trapframe, fixreg[24])); 160ASSYM(FRAME_25, offsetof(struct trapframe, fixreg[25])); 161ASSYM(FRAME_26, offsetof(struct trapframe, fixreg[26])); 162ASSYM(FRAME_27, offsetof(struct trapframe, fixreg[27])); 163ASSYM(FRAME_28, offsetof(struct trapframe, fixreg[28])); 164ASSYM(FRAME_29, offsetof(struct trapframe, fixreg[29])); 165ASSYM(FRAME_30, offsetof(struct trapframe, fixreg[30])); 166ASSYM(FRAME_31, offsetof(struct trapframe, fixreg[31])); 167ASSYM(FRAME_LR, offsetof(struct trapframe, lr)); 168ASSYM(FRAME_CR, offsetof(struct trapframe, cr)); 169ASSYM(FRAME_CTR, offsetof(struct trapframe, ctr)); 170ASSYM(FRAME_XER, offsetof(struct trapframe, xer)); 171ASSYM(FRAME_SRR0, offsetof(struct trapframe, srr0)); 172ASSYM(FRAME_SRR1, offsetof(struct trapframe, srr1)); 173ASSYM(FRAME_EXC, offsetof(struct trapframe, exc)); 174ASSYM(FRAME_AIM_DAR, offsetof(struct trapframe, cpu.aim.dar)); 175ASSYM(FRAME_AIM_DSISR, offsetof(struct trapframe, cpu.aim.dsisr)); 176ASSYM(FRAME_BOOKE_DEAR, offsetof(struct trapframe, cpu.booke.dear)); 177ASSYM(FRAME_BOOKE_ESR, offsetof(struct trapframe, cpu.booke.esr)); 178ASSYM(FRAME_BOOKE_DBCR0, offsetof(struct trapframe, cpu.booke.dbcr0)); 179 180ASSYM(CF_FUNC, offsetof(struct callframe, cf_func)); 181ASSYM(CF_ARG0, offsetof(struct callframe, cf_arg0)); 182ASSYM(CF_ARG1, offsetof(struct callframe, cf_arg1)); 183ASSYM(CF_SIZE, sizeof(struct callframe)); 184 185ASSYM(PCB_CONTEXT, offsetof(struct pcb, pcb_context)); 186ASSYM(PCB_CR, offsetof(struct pcb, pcb_cr)); 187ASSYM(PCB_SP, offsetof(struct pcb, pcb_sp)); 188ASSYM(PCB_TOC, offsetof(struct pcb, pcb_toc)); 189ASSYM(PCB_LR, offsetof(struct pcb, pcb_lr)); 190ASSYM(PCB_ONFAULT, offsetof(struct pcb, pcb_onfault)); 191ASSYM(PCB_FLAGS, offsetof(struct pcb, pcb_flags)); 192ASSYM(PCB_FPU, PCB_FPU); 193ASSYM(PCB_VEC, PCB_VEC); 194 195ASSYM(PCB_AIM_USR_VSID, offsetof(struct pcb, pcb_cpu.aim.usr_vsid)); 196ASSYM(PCB_BOOKE_CTR, offsetof(struct pcb, pcb_cpu.booke.ctr)); 197ASSYM(PCB_BOOKE_XER, offsetof(struct pcb, pcb_cpu.booke.xer)); 198ASSYM(PCB_BOOKE_DBCR0, offsetof(struct pcb, pcb_cpu.booke.dbcr0)); 199 200ASSYM(TD_LOCK, offsetof(struct thread, td_lock)); 201ASSYM(TD_PROC, offsetof(struct thread, td_proc)); 202ASSYM(TD_PCB, offsetof(struct thread, td_pcb)); 203 204ASSYM(P_VMSPACE, offsetof(struct proc, p_vmspace)); 205 206ASSYM(VM_PMAP, offsetof(struct vmspace, vm_pmap)); 207 208ASSYM(TD_FLAGS, offsetof(struct thread, td_flags)); 209 210ASSYM(TDF_ASTPENDING, TDF_ASTPENDING); 211ASSYM(TDF_NEEDRESCHED, TDF_NEEDRESCHED); 212 213ASSYM(SF_UC, offsetof(struct sigframe, sf_uc)); 214 215ASSYM(KERNBASE, KERNBASE); 216ASSYM(MAXCOMLEN, MAXCOMLEN); 217 218ASSYM(PSL_DE, PSL_DE); 219ASSYM(PSL_DS, PSL_DS); 220ASSYM(PSL_IS, PSL_IS); 221ASSYM(PSL_CE, PSL_CE); 222ASSYM(PSL_UCLE, PSL_UCLE); 223ASSYM(PSL_WE, PSL_WE); 224ASSYM(PSL_UBLE, PSL_UBLE); 225 226#if defined(BOOKE_E500) 227ASSYM(PSL_KERNSET_INIT, PSL_KERNSET_INIT); 228#endif 229 230#if defined(AIM) && defined(__powerpc64__) 231ASSYM(PSL_SF, PSL_SF); 232ASSYM(PSL_HV, PSL_HV); 233#endif 234 235ASSYM(PSL_POW, PSL_POW); 236ASSYM(PSL_ILE, PSL_ILE); 237ASSYM(PSL_LE, PSL_LE); 238ASSYM(PSL_SE, PSL_SE); 239ASSYM(PSL_RI, PSL_RI); 240ASSYM(PSL_DR, PSL_DR); 241ASSYM(PSL_IP, PSL_IP); 242ASSYM(PSL_IR, PSL_IR); 243 244ASSYM(PSL_FE_DIS, PSL_FE_DIS); 245ASSYM(PSL_FE_NONREC, PSL_FE_NONREC); 246ASSYM(PSL_FE_PREC, PSL_FE_PREC); 247ASSYM(PSL_FE_REC, PSL_FE_REC); 248 249ASSYM(PSL_VEC, PSL_VEC); 250ASSYM(PSL_BE, PSL_BE); 251ASSYM(PSL_EE, PSL_EE); 252ASSYM(PSL_FE0, PSL_FE0); 253ASSYM(PSL_FE1, PSL_FE1); 254ASSYM(PSL_FP, PSL_FP); 255ASSYM(PSL_ME, PSL_ME); 256ASSYM(PSL_PR, PSL_PR); 257ASSYM(PSL_PMM, PSL_PMM); 258ASSYM(PSL_KERNSET, PSL_KERNSET); 259ASSYM(PSL_USERSET, PSL_USERSET); 260ASSYM(PSL_USERSTATIC, PSL_USERSTATIC); 261 262