/* * Copyright (c) 1993 The Hewlett-Packard Development Company * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer; * redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution; * neither the name of the copyright holders nor the names of its * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #ifndef EV5_IMPURE_INCLUDED #define EV5_IMPURE_INCLUDED // This uses the Hudson file format from "impure.h" but with the fields from // the distrubuted palcode "ev5_impure.sdl" .. pboyle Nov/95 // file: impure.sdl // // PAL impure scratch area and logout area data structure definitions for // Alpha firmware. // // // module $pal_impure; // // Edit Date Who Description // ---- --------- --- --------------------- // 1 7-Jul-93 JEM Initial Entry // 2 18-nov-93 JEM Add shadow bc_ctl and pmctr_ctl to impure area // Delete mvptbr // Calculate pal$logout from end of impure area // 3 6-dec-93 JEM Add pmctr_ctl bitfield definitions // 4 3-feb-94 JEM Remove f31,r31 from impure area; Remove bc_ctl, // pmctr_ctl; add ic_perr_stat, pmctr, dc_perr_stat, // sc_stat, sc_addr, sc_ctl, bc_tag_addr, ei_stat, // ei_addr, fill_syn, ld_lock // 5 19-feb-94 JEM add gpr constants, and add f31,r31 back in to be // consistent with ev4 // add cns$ipr_offset // 6 18-apr-94 JEM Add shadow bc_ctl and pmctr_ctl to impure area again. // 7 18-jul-94 JEM Add bc_config shadow. Add mchk$sys_base constant // to mchk logout frame // // // constant REVISION equals 7 prefix IMPURE$; // Revision number of this file //orig /* ** Macros for saving/restoring data to/from the PAL impure scratch ** area. ** ** The console save state area is larger than the addressibility ** of the HW_LD/ST instructions (10-bit signed byte displacement), ** so some adjustments to the base offsets, as well as the offsets ** within each base region, are necessary. ** ** The console save state area is divided into two segments; the ** CPU-specific segment and the platform-specific segment. The ** state that is saved in the CPU-specific segment includes GPRs, ** FPRs, IPRs, halt code, MCHK flag, etc. All other state is saved ** in the platform-specific segment. ** ** The impure pointer will need to be adjusted by a different offset ** value for each region within a given segment. The SAVE and RESTORE ** macros will auto-magically adjust the offsets accordingly. ** */ //#define SEXT10(X) (((X) & 0x200) ? ((X) | 0xfffffffffffffc00) : (X)) #define SEXT10(X) ((X) & 0x3ff) //#define SEXT10(X) (((X) << 55) >> 55) #define SAVE_GPR(reg,offset,base) \ stq_p reg, (SEXT10(offset-0x200))(base) #define RESTORE_GPR(reg,offset,base) \ ldq_p reg, (SEXT10(offset-0x200))(base) #define SAVE_FPR(reg,offset,base) \ stt reg, (SEXT10(offset-0x200))(base) #define RESTORE_FPR(reg,offset,base) \ ldt reg, (SEXT10(offset-0x200))(base) #define SAVE_IPR(reg,offset,base) \ mfpr v0, reg; \ stq_p v0, (SEXT10(offset-CNS_Q_IPR))(base) #define RESTORE_IPR(reg,offset,base) \ ldq_p v0, (SEXT10(offset-CNS_Q_IPR))(base); \ mtpr v0, reg #define SAVE_SHADOW(reg,offset,base) \ stq_p reg, (SEXT10(offset-CNS_Q_IPR))(base) #define RESTORE_SHADOW(reg,offset,base)\ ldq_p reg, (SEXT10(offset-CNS_Q_IPR))(base) /* Structure of the processor-specific impure area */ /* aggregate impure struct prefix "" tag ""; * cns$flag quadword; * cns$hlt quadword; */ /* Define base for debug monitor compatibility */ #define CNS_Q_BASE 0x000 #define CNS_Q_FLAG 0x100 #define CNS_Q_HALT 0x108 /* constant ( * cns$r0,cns$r1,cns$r2,cns$r3,cns$r4,cns$r5,cns$r6,cns$r7, * cns$r8,cns$r9,cns$r10,cns$r11,cns$r12,cns$r13,cns$r14,cns$r15, * cns$r16,cns$r17,cns$r18,cns$r19,cns$r20,cns$r21,cns$r22,cns$r23, * cns$r24,cns$r25,cns$r26,cns$r27,cns$r28,cns$r29,cns$r30,cns$r31 * ) equals . increment 8 prefix "" tag ""; * cns$gpr quadword dimension 32; */ /* Offset to base of saved GPR area - 32 quadword */ #define CNS_Q_GPR 0x110 #define cns_gpr CNS_Q_GPR /* constant ( * cns$f0,cns$f1,cns$f2,cns$f3,cns$f4,cns$f5,cns$f6,cns$f7, * cns$f8,cns$f9,cns$f10,cns$f11,cns$f12,cns$f13,cns$f14,cns$f15, * cns$f16,cns$f17,cns$f18,cns$f19,cns$f20,cns$f21,cns$f22,cns$f23, * cns$f24,cns$f25,cns$f26,cns$f27,cns$f28,cns$f29,cns$f30,cns$f31 * ) equals . increment 8 prefix "" tag ""; * cns$fpr quadword dimension 32; */ /* Offset to base of saved FPR area - 32 quadwords */ #define CNS_Q_FPR 0x210 /* #t=.; * cns$mchkflag quadword; */ #define CNS_Q_MCHK 0x310 /* constant cns$pt_offset equals .; * constant ( * cns$pt0,cns$pt1,cns$pt2,cns$pt3,cns$pt4,cns$pt5,cns$pt6, * cns$pt7,cns$pt8,cns$pt9,cns$pt10,cns$pt11,cns$pt12,cns$pt13, * cns$pt14,cns$pt15,cns$pt16,cns$pt17,cns$pt18,cns$pt19,cns$pt20, * cns$pt21,cns$pt22,cns$pt23 * ) equals . increment 8 prefix "" tag ""; * cns$pt quadword dimension 24; */ /* Offset to base of saved PALtemp area - 25 quadwords */ #define CNS_Q_PT 0x318 /* cns$shadow8 quadword; * cns$shadow9 quadword; * cns$shadow10 quadword; * cns$shadow11 quadword; * cns$shadow12 quadword; * cns$shadow13 quadword; * cns$shadow14 quadword; * cns$shadow25 quadword; */ /* Offset to base of saved PALshadow area - 8 quadwords */ #define CNS_Q_SHADOW 0x3D8 /* Offset to base of saved IPR area */ #define CNS_Q_IPR 0x418 /* constant cns$ipr_offset equals .; */ /* cns$exc_addr quadword; */ #define CNS_Q_EXC_ADDR 0x418 /* cns$pal_base quadword; */ #define CNS_Q_PAL_BASE 0x420 /* cns$mm_stat quadword; */ #define CNS_Q_MM_STAT 0x428 /* cns$va quadword; */ #define CNS_Q_VA 0x430 /* cns$icsr quadword; */ #define CNS_Q_ICSR 0x438 /* cns$ipl quadword; */ #define CNS_Q_IPL 0x440 /* cns$ps quadword; // Ibox current mode */ #define CNS_Q_IPS 0x448 /* cns$itb_asn quadword; */ #define CNS_Q_ITB_ASN 0x450 /* cns$aster quadword; */ #define CNS_Q_ASTER 0x458 /* cns$astrr quadword; */ #define CNS_Q_ASTRR 0x460 /* cns$isr quadword; */ #define CNS_Q_ISR 0x468 /* cns$ivptbr quadword; */ #define CNS_Q_IVPTBR 0x470 /* cns$mcsr quadword; */ #define CNS_Q_MCSR 0x478 /* cns$dc_mode quadword; */ #define CNS_Q_DC_MODE 0x480 /* cns$maf_mode quadword; */ #define CNS_Q_MAF_MODE 0x488 /* cns$sirr quadword; */ #define CNS_Q_SIRR 0x490 /* cns$fpcsr quadword; */ #define CNS_Q_FPCSR 0x498 /* cns$icperr_stat quadword; */ #define CNS_Q_ICPERR_STAT 0x4A0 /* cns$pmctr quadword; */ #define CNS_Q_PM_CTR 0x4A8 /* cns$exc_sum quadword; */ #define CNS_Q_EXC_SUM 0x4B0 /* cns$exc_mask quadword; */ #define CNS_Q_EXC_MASK 0x4B8 /* cns$intid quadword; */ #define CNS_Q_INT_ID 0x4C0 /* cns$dcperr_stat quadword; */ #define CNS_Q_DCPERR_STAT 0x4C8 /* cns$sc_stat quadword; */ #define CNS_Q_SC_STAT 0x4D0 /* cns$sc_addr quadword; */ #define CNS_Q_SC_ADDR 0x4D8 /* cns$sc_ctl quadword; */ #define CNS_Q_SC_CTL 0x4E0 /* cns$bc_tag_addr quadword; */ #define CNS_Q_BC_TAG_ADDR 0x4E8 /* cns$ei_stat quadword; */ #define CNS_Q_EI_STAT 0x4F0 /* cns$ei_addr quadword; */ #define CNS_Q_EI_ADDR 0x4F8 /* cns$fill_syn quadword; */ #define CNS_Q_FILL_SYN 0x500 /* cns$ld_lock quadword; */ #define CNS_Q_LD_LOCK 0x508 /* cns$bc_ctl quadword; // shadow of on chip bc_ctl */ #define CNS_Q_BC_CTL 0x510 /* cns$pmctr_ctl quadword; // saved frequency select info for performance monitor counter */ #define CNS_Q_PM_CTL 0x518 /* cns$bc_config quadword; // shadow of on chip bc_config */ #define CNS_Q_BC_CFG 0x520 /* constant cns$size equals .; * * constant pal$impure_common_size equals (%x0200 +7) & %xfff8; * constant pal$impure_specific_size equals (.+7) & %xfff8; * constant cns$mchksize equals (.+7-#t) & %xfff8; * constant pal$logout_area equals pal$impure_specific_size ; * end impure; */ /* This next set of stuff came from the old code ..pb */ #define CNS_Q_SROM_REV 0x528 #define CNS_Q_PROC_ID 0x530 #define CNS_Q_MEM_SIZE 0x538 #define CNS_Q_CYCLE_CNT 0x540 #define CNS_Q_SIGNATURE 0x548 #define CNS_Q_PROC_MASK 0x550 #define CNS_Q_SYSCTX 0x558 #define MACHINE_CHECK_CRD_BASE 0 #define MACHINE_CHECK_SIZE ((CNS_Q_SYSCTX + 7 - CNS_Q_MCHK) & 0xfff8) /* * aggregate EV5PMCTRCTL_BITS structure fill prefix PMCTR_CTL$; * SPROCESS bitfield length 1 ; * FILL_0 bitfield length 3 fill tag $$; * FRQ2 bitfield length 2 ; * FRQ1 bitfield length 2 ; * FRQ0 bitfield length 2 ; * CTL2 bitfield length 2 ; * CTL1 bitfield length 2 ; * CTL0 bitfield length 2 ; * FILL_1 bitfield length 16 fill tag $$; * FILL_2 bitfield length 32 fill tag $$; * end EV5PMCTRCTL_BITS; * * end_module $pal_impure; * * module $pal_logout; * * // * // Start definition of Corrected Error Frame * // */ /* * aggregate crd_logout struct prefix "" tag ""; */ #define pal_logout_area 0x600 #define mchk_crd_base 0 /* mchk$crd_flag quadword; */ #define mchk_crd_flag 0 /* mchk$crd_offsets quadword; */ #define mchk_crd_offsets 8 /* * // Pal-specific information */ #define mchk_crd_mchk_code 0x10 /* mchk$crd_mchk_code quadword; * * // CPU-specific information * constant mchk$crd_cpu_base equals . ; * mchk$crd_ei_addr quadword; */ #define mchk_crd_ei_addr 0x18 /* mchk$crd_fill_syn quadword; */ #define mchk_crd_fill_syn 0x20 /* mchk$crd_ei_stat quadword; */ #define mchk_crd_ei_stat 0x28 /* mchk$crd_isr quadword; */ #define mchk_crd_isr 0x30 /* * Hacked up constants for the turbolaser build. Hope * this is moreless correct */ #define mchk_crd_whami 0x38 #define mchk_crd_tldev 0x40 #define mchk_crd_tlber 0x48 #define mchk_crd_tlesr0 0x50 #define mchk_crd_tlesr1 0x58 #define mchk_crd_tlesr2 0x60 #define mchk_crd_tlesr3 0x68 #define mchk_crd_rsvd 0x70 /* * mchk area seems different for tlaser */ #define mchk_crd_size 0x80 #define mchk_mchk_base (mchk_crd_size) #define mchk_tlber 0x0 #define mchk_tlepaerr 0x8 #define mchk_tlepderr 0x10 #define mchk_tlepmerr 0x18 /* * // System-specific information * constant mchk$crd_sys_base equals . ; * constant mchk$crd_size equals (.+7) & %xfff8; * * end crd_logout; * // * // Start definition of Machine check logout Frame * // * aggregate logout struct prefix "" tag ""; * mchk$flag quadword; */ /* mchk$offsets quadword; */ /* * // Pal-specific information * mchk$mchk_code quadword; */ /* * mchk$pt quadword dimension 24; * * // CPU-specific information * constant mchk$cpu_base equals . ; * mchk$exc_addr quadword; * mchk$exc_sum quadword; * mchk$exc_mask quadword; * mchk$pal_base quadword; * mchk$isr quadword; * mchk$icsr quadword; * mchk$ic_perr_stat quadword; * mchk$dc_perr_stat quadword; * mchk$va quadword; * mchk$mm_stat quadword; * mchk$sc_addr quadword; * mchk$sc_stat quadword; * mchk$bc_tag_addr quadword; * mchk$ei_addr quadword; * mchk$fill_syn quadword; * mchk$ei_stat quadword; * mchk$ld_lock quadword; * * // System-specific information * * constant mchk$sys_base equals . ; * mchk$sys_ipr1 quadword ; // Holder for system-specific stuff * * constant mchk$size equals (.+7) & %xfff8; * * * constant mchk$crd_base equals 0 ; * constant mchk$mchk_base equals mchk$crd_size ; * * * end logout; * * end_module $pal_logout; */ /* * this is lingering in the old ladbx code but looks like it was from * ev4 days. This was 0x160 in the old days..pb */ #define LAF_K_SIZE MACHINE_CHECK_SIZE #endif