ev5_alpha_defs.h revision 8029
112855Sgabeblack@google.com/* 212855Sgabeblack@google.com * Copyright (c) 1993 The Hewlett-Packard Development Company 312855Sgabeblack@google.com * All rights reserved. 412855Sgabeblack@google.com * 512855Sgabeblack@google.com * Redistribution and use in source and binary forms, with or without 612855Sgabeblack@google.com * modification, are permitted provided that the following conditions are 712855Sgabeblack@google.com * met: redistributions of source code must retain the above copyright 812855Sgabeblack@google.com * notice, this list of conditions and the following disclaimer; 912855Sgabeblack@google.com * redistributions in binary form must reproduce the above copyright 1012855Sgabeblack@google.com * notice, this list of conditions and the following disclaimer in the 1112855Sgabeblack@google.com * documentation and/or other materials provided with the distribution; 1212855Sgabeblack@google.com * neither the name of the copyright holders nor the names of its 1312855Sgabeblack@google.com * contributors may be used to endorse or promote products derived from 1412855Sgabeblack@google.com * this software without specific prior written permission. 1512855Sgabeblack@google.com * 1612855Sgabeblack@google.com * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 1712855Sgabeblack@google.com * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 1812855Sgabeblack@google.com * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 1912855Sgabeblack@google.com * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 2012855Sgabeblack@google.com * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 2112855Sgabeblack@google.com * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 2212855Sgabeblack@google.com * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 2312855Sgabeblack@google.com * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 2412855Sgabeblack@google.com * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 2512855Sgabeblack@google.com * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 2612855Sgabeblack@google.com * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 2712855Sgabeblack@google.com */ 2812855Sgabeblack@google.com 2912855Sgabeblack@google.com#ifndef EV5_ALPHA_DEFS_INCLUDED 3012855Sgabeblack@google.com#define EV5_ALPHA_DEFS_INCLUDED 1 3112855Sgabeblack@google.com 3212855Sgabeblack@google.com// from ev5_alpha_defs.mar from Lance's fetch directory 3312855Sgabeblack@google.com// Lower-caseified and $ signs removed ... pb Nov/95 3412855Sgabeblack@google.com 3512855Sgabeblack@google.com// 3612855Sgabeblack@google.com// PS Layout - PS 3712855Sgabeblack@google.com// Loc Size name function 3812855Sgabeblack@google.com// ------ ------ ______ ----------------------------------- 3912855Sgabeblack@google.com// <31:29> 3 SA stack alignment 4012855Sgabeblack@google.com// <31:13> 24 RES Reserved MBZ 4112855Sgabeblack@google.com// <12:8> 5 IPL Priority level 4212855Sgabeblack@google.com// <7> 1 VMM Virtual Mach Monitor 4312855Sgabeblack@google.com// <6:5> 2 RES Reserved MBZ 4412855Sgabeblack@google.com// <4:3> 2 CM Current Mode 4512855Sgabeblack@google.com// <2> 1 IP Interrupt Pending 4612855Sgabeblack@google.com// <1:0> 2 SW Software bits 4712855Sgabeblack@google.com// 4812855Sgabeblack@google.com 4912855Sgabeblack@google.com#define ps_v_sw 0 5012855Sgabeblack@google.com#define ps_m_sw (3<<ps_v_sw) 5112855Sgabeblack@google.com 5212855Sgabeblack@google.com#define ps_v_ip 2 5312855Sgabeblack@google.com#define ps_m_ip (1<<ps_v_ip) 5412855Sgabeblack@google.com 5512855Sgabeblack@google.com#define ps_v_cm 3 5612855Sgabeblack@google.com#define ps_m_cm (3<<ps_v_cm) 5712855Sgabeblack@google.com 5812855Sgabeblack@google.com#define ps_v_vmm 7 5912855Sgabeblack@google.com#define ps_m_vmm (1<<ps_v_vmm) 6012855Sgabeblack@google.com 6112855Sgabeblack@google.com#define ps_v_ipl 8 6212855Sgabeblack@google.com#define ps_m_ipl (0x1f<<ps_v_ipl) 6312855Sgabeblack@google.com 6412855Sgabeblack@google.com#define ps_v_sp (0x38) 6512855Sgabeblack@google.com#define ps_m_sp (0x3f<<ps_v_sp) 6612855Sgabeblack@google.com 6712855Sgabeblack@google.com 6812855Sgabeblack@google.com#define ps_c_kern (0x00) 6912855Sgabeblack@google.com#define ps_c_exec (0x08) 7012855Sgabeblack@google.com#define ps_c_supr (0x10) 7112855Sgabeblack@google.com#define ps_c_user (0x18) 7212855Sgabeblack@google.com#define ps_c_ipl0 (0x0000) 7312855Sgabeblack@google.com#define ps_c_ipl1 (0x0100) 7412855Sgabeblack@google.com#define ps_c_ipl2 (0x0200) 7512855Sgabeblack@google.com#define ps_c_ipl3 (0x0300) 7612855Sgabeblack@google.com#define ps_c_ipl4 (0x0400) 7712855Sgabeblack@google.com#define ps_c_ipl5 (0x0500) 7812855Sgabeblack@google.com#define ps_c_ipl6 (0x0600) 7912855Sgabeblack@google.com#define ps_c_ipl7 (0x0700) 8012855Sgabeblack@google.com#define ps_c_ipl8 (0x0800) 8112855Sgabeblack@google.com#define ps_c_ipl9 (0x0900) 8212855Sgabeblack@google.com#define ps_c_ipl10 (0x0A00) 8312855Sgabeblack@google.com#define ps_c_ipl11 (0x0B00) 8412855Sgabeblack@google.com#define ps_c_ipl12 (0x0C00) 8512855Sgabeblack@google.com#define ps_c_ipl13 (0x0D00) 8612855Sgabeblack@google.com#define ps_c_ipl14 (0x0E00) 8712855Sgabeblack@google.com#define ps_c_ipl15 (0x0F00) 8812855Sgabeblack@google.com#define ps_c_ipl16 (0x1000) 8912855Sgabeblack@google.com#define ps_c_ipl17 (0x1100) 9012855Sgabeblack@google.com#define ps_c_ipl18 (0x1200) 9112855Sgabeblack@google.com#define ps_c_ipl19 (0x1300) 9212855Sgabeblack@google.com#define ps_c_ipl20 (0x1400) 9312855Sgabeblack@google.com#define ps_c_ipl21 (0x1500) 9412855Sgabeblack@google.com#define ps_c_ipl22 (0x1600) 9512855Sgabeblack@google.com#define ps_c_ipl23 (0x1700) 9612855Sgabeblack@google.com#define ps_c_ipl24 (0x1800) 9712855Sgabeblack@google.com#define ps_c_ipl25 (0x1900) 9812855Sgabeblack@google.com#define ps_c_ipl26 (0x1A00) 9912855Sgabeblack@google.com#define ps_c_ipl27 (0x1B00) 10012855Sgabeblack@google.com#define ps_c_ipl28 (0x1C00) 10112855Sgabeblack@google.com#define ps_c_ipl29 (0x1D00) 10212855Sgabeblack@google.com#define ps_c_ipl30 (0x1E00) 10312855Sgabeblack@google.com#define ps_c_ipl31 (0x1F00) 10412855Sgabeblack@google.com 10512855Sgabeblack@google.com// 10612855Sgabeblack@google.com// PTE layout - symbol prefix PTE_ 10712855Sgabeblack@google.com// 10812855Sgabeblack@google.com// Loc Size name function 10912855Sgabeblack@google.com// ------ ------ ------ ----------------------------------- 11012855Sgabeblack@google.com// <63:32> 32 PFN Page Frame Number 11112855Sgabeblack@google.com// <31:16> 16 SOFT Bits reserved for software use 11212855Sgabeblack@google.com// <15> 1 UWE User write enable 11312855Sgabeblack@google.com// <14> 1 SWE Super write enable 11412855Sgabeblack@google.com// <13> 1 EWE Exec write enable 11512855Sgabeblack@google.com// <12> 1 KWE Kernel write enable 11612855Sgabeblack@google.com// <11> 1 URE User read enable 11712855Sgabeblack@google.com// <10> 1 SRE Super read enable 11812855Sgabeblack@google.com// <9> 1 ERE Exec read enable 11912855Sgabeblack@google.com// <8> 1 KRE Kernel read enable 12012855Sgabeblack@google.com// <7:6> 2 RES Reserved SBZ 12112855Sgabeblack@google.com// <5> 1 HPF Huge Page Flag 12212855Sgabeblack@google.com// <4> 1 ASM Wild card address space number match 12312855Sgabeblack@google.com// <3> 1 FOE Fault On execute 12412855Sgabeblack@google.com// <2> 1 FOW Fault On Write 12512855Sgabeblack@google.com// <1> 1 FOR Fault On Read 12612855Sgabeblack@google.com// <0> 1 V valid bit 12712855Sgabeblack@google.com// 12812855Sgabeblack@google.com 12912855Sgabeblack@google.com#define pte_v_pfn 32 13012855Sgabeblack@google.com#define pte_m_soft (0xFFFF0000) 13112855Sgabeblack@google.com#define pte_v_soft 16 13212855Sgabeblack@google.com#define pte_m_uwe (0x8000) 13312855Sgabeblack@google.com#define pte_v_uwe 15 13412855Sgabeblack@google.com#define pte_m_swe (0x4000) 13512855Sgabeblack@google.com#define pte_v_swe 14 13612855Sgabeblack@google.com#define pte_m_ewe (0x2000) 13712855Sgabeblack@google.com#define pte_v_ewe 13 13812855Sgabeblack@google.com#define pte_m_kwe (0x1000) 13912855Sgabeblack@google.com#define pte_v_kwe 12 14012855Sgabeblack@google.com#define pte_m_ure (0x0800) 14112855Sgabeblack@google.com#define pte_v_ure 11 14212855Sgabeblack@google.com#define pte_m_sre (0x0400) 14312855Sgabeblack@google.com#define pte_v_sre 10 14412855Sgabeblack@google.com#define pte_m_ere (0x0200) 14512855Sgabeblack@google.com#define pte_v_ere 9 14612855Sgabeblack@google.com#define pte_m_kre (0x0100) 14712855Sgabeblack@google.com#define pte_v_kre 8 14812855Sgabeblack@google.com#define pte_m_hpf (0x0020) 14912855Sgabeblack@google.com#define pte_v_hpf 5 15012855Sgabeblack@google.com#define pte_m_asm (0x0010) 15112855Sgabeblack@google.com#define pte_v_asm 4 15212855Sgabeblack@google.com#define pte_m_foe (0x0008) 15312855Sgabeblack@google.com#define pte_v_foe 3 15412855Sgabeblack@google.com#define pte_m_fow (0x0004) 15512855Sgabeblack@google.com#define pte_v_fow 2 15612855Sgabeblack@google.com#define pte_m_for (0x0002) 15712855Sgabeblack@google.com#define pte_v_for 1 15812855Sgabeblack@google.com#define pte_m_v (0x0001) 15912855Sgabeblack@google.com#define pte_v_v 0 16012855Sgabeblack@google.com 16112855Sgabeblack@google.com// 16212855Sgabeblack@google.com// VA layout - symbol prefix VA_ 16312855Sgabeblack@google.com// 16412855Sgabeblack@google.com// Loc Size name function 16512855Sgabeblack@google.com// ------ ------ ------- ----------------------------------- 16612855Sgabeblack@google.com// <42:33> 10 SEG1 First seg table offset for mapping 16712855Sgabeblack@google.com// <32:23> 10 SEG2 Second seg table offset for mapping 16812855Sgabeblack@google.com// <22:13> 10 SEG3 Third seg table offset for mapping 16912855Sgabeblack@google.com// <12:0> 13 OFFSET Byte within page 17012855Sgabeblack@google.com// 17112855Sgabeblack@google.com 17212855Sgabeblack@google.com#define va_m_offset (0x000000001FFF) 17312855Sgabeblack@google.com#define va_v_offset 0 17412855Sgabeblack@google.com#define va_m_seg3 (0x0000007FE000) 17512855Sgabeblack@google.com#define va_v_seg3 13 17612855Sgabeblack@google.com#define va_m_seg2 (0x0001FF800000) 17712855Sgabeblack@google.com#define va_v_seg2 23 17812855Sgabeblack@google.com#define va_m_seg1 (0x7FE00000000) 17912855Sgabeblack@google.com#define va_v_seg1 33 18012855Sgabeblack@google.com 18112855Sgabeblack@google.com// 18212855Sgabeblack@google.com//PRIVILEGED CONTEXT BLOCK (PCB) 18312855Sgabeblack@google.com// 18412855Sgabeblack@google.com#define pcb_q_ksp 0 18512855Sgabeblack@google.com#define pcb_q_esp 8 18612855Sgabeblack@google.com#define pcb_q_ssp 16 18712855Sgabeblack@google.com#define pcb_q_usp 24 18812855Sgabeblack@google.com#define pcb_q_ptbr 32 18912855Sgabeblack@google.com#define pcb_q_asn 40 19012855Sgabeblack@google.com#define pcb_q_ast 48 19112855Sgabeblack@google.com#define pcb_q_fen 56 19212855Sgabeblack@google.com#define pcb_q_cc 64 19312855Sgabeblack@google.com#define pcb_q_unq 72 19412855Sgabeblack@google.com#define pcb_q_sct 80 19512855Sgabeblack@google.com 19612855Sgabeblack@google.com#define pcb_v_asten 0 19712855Sgabeblack@google.com#define pcb_m_asten (0x0f<<pcb_v_asten) 19812855Sgabeblack@google.com#define pcb_v_astsr 4 19912855Sgabeblack@google.com#define pcb_m_astsr (0x0f<<pcb_v_astsr) 20012855Sgabeblack@google.com#define pcb_v_dat 63 20112855Sgabeblack@google.com#define pcb_v_pme 62 20212855Sgabeblack@google.com 20312855Sgabeblack@google.com// 20412855Sgabeblack@google.com// SYSTEM CONTROL BLOCK (SCB) 20512855Sgabeblack@google.com// 20612855Sgabeblack@google.com 20712855Sgabeblack@google.com#define scb_v_fen (0x0010) 20812855Sgabeblack@google.com#define scb_v_acv (0x0080) 20912855Sgabeblack@google.com#define scb_v_tnv (0x0090) 21012855Sgabeblack@google.com#define scb_v_for (0x00A0) 21112855Sgabeblack@google.com#define scb_v_fow (0x00B0) 21212855Sgabeblack@google.com#define scb_v_foe (0x00C0) 21312855Sgabeblack@google.com#define scb_v_arith (0x0200) 21412855Sgabeblack@google.com#define scb_v_kast (0x0240) 21512855Sgabeblack@google.com#define scb_v_east (0x0250) 21612855Sgabeblack@google.com#define scb_v_sast (0x0260) 21712855Sgabeblack@google.com#define scb_v_uast (0x0270) 21812855Sgabeblack@google.com#define scb_v_unalign (0x0280) 21912855Sgabeblack@google.com#define scb_v_bpt (0x0400) 22012855Sgabeblack@google.com#define scb_v_bugchk (0x0410) 22112855Sgabeblack@google.com#define scb_v_opcdec (0x0420) 22212855Sgabeblack@google.com#define scb_v_illpal (0x0430) 22312855Sgabeblack@google.com#define scb_v_trap (0x0440) 22412855Sgabeblack@google.com#define scb_v_chmk (0x0480) 22512855Sgabeblack@google.com#define scb_v_chme (0x0490) 22612855Sgabeblack@google.com#define scb_v_chms (0x04A0) 22712855Sgabeblack@google.com#define scb_v_chmu (0x04B0) 22812855Sgabeblack@google.com#define scb_v_sw0 (0x0500) 22912855Sgabeblack@google.com#define scb_v_sw1 (0x0510) 23012855Sgabeblack@google.com#define scb_v_sw2 (0x0520) 23112855Sgabeblack@google.com#define scb_v_sw3 (0x0530) 23212855Sgabeblack@google.com#define scb_v_sw4 (0x0540) 23312855Sgabeblack@google.com#define scb_v_sw5 (0x0550) 23412855Sgabeblack@google.com#define scb_v_sw6 (0x0560) 23512855Sgabeblack@google.com#define scb_v_sw7 (0x0570) 23612855Sgabeblack@google.com#define scb_v_sw8 (0x0580) 23712855Sgabeblack@google.com#define scb_v_sw9 (0x0590) 23812855Sgabeblack@google.com#define scb_v_sw10 (0x05A0) 23912855Sgabeblack@google.com#define scb_v_sw11 (0x05B0) 24012855Sgabeblack@google.com#define scb_v_sw12 (0x05C0) 24112855Sgabeblack@google.com#define scb_v_sw13 (0x05D0) 24212855Sgabeblack@google.com#define scb_v_sw14 (0x05E0) 24312855Sgabeblack@google.com#define scb_v_sw15 (0x05F0) 24412855Sgabeblack@google.com#define scb_v_clock (0x0600) 24512855Sgabeblack@google.com#define scb_v_inter (0x0610) 24612855Sgabeblack@google.com#define scb_v_sys_corr_err (0x0620) 24712855Sgabeblack@google.com#define scb_v_proc_corr_err (0x0630) 24812855Sgabeblack@google.com#define scb_v_pwrfail (0x0640) 24912855Sgabeblack@google.com#define scb_v_perfmon (0x0650) 25012855Sgabeblack@google.com#define scb_v_sysmchk (0x0660) 25112855Sgabeblack@google.com#define scb_v_procmchk (0x0670) 25212855Sgabeblack@google.com#define scb_v_passive_rel (0x06F0) 25312855Sgabeblack@google.com 25412855Sgabeblack@google.com// 25512855Sgabeblack@google.com// Stack frame (FRM) 25612855Sgabeblack@google.com// 25712855Sgabeblack@google.com 25812855Sgabeblack@google.com#define frm_v_r2 (0x0000) 25912855Sgabeblack@google.com#define frm_v_r3 (0x0008) 26012855Sgabeblack@google.com#define frm_v_r4 (0x0010) 26112855Sgabeblack@google.com#define frm_v_r5 (0x0018) 26212855Sgabeblack@google.com#define frm_v_r6 (0x0020) 26312855Sgabeblack@google.com#define frm_v_r7 (0x0028) 26412855Sgabeblack@google.com#define frm_v_pc (0x0030) 26512855Sgabeblack@google.com#define frm_v_ps (0x0038) 26612855Sgabeblack@google.com 26712855Sgabeblack@google.com// 26812855Sgabeblack@google.com// Exeception summary register (EXS) 26912855Sgabeblack@google.com// 27012855Sgabeblack@google.com// exs_v_swc <0> ; Software completion 27112855Sgabeblack@google.com// exs_v_inv <1> ; Ivalid operation 27212855Sgabeblack@google.com// exs_v_dze <2> ; Div by zero 27312855Sgabeblack@google.com// exs_v_fov <3> ; Floating point overflow 27412855Sgabeblack@google.com// exs_v_unf <4> ; Floating point underflow 27512855Sgabeblack@google.com// exs_v_ine <5> ; Floating point inexact 27612855Sgabeblack@google.com// exs_v_iov <6> ; Floating convert to integer overflow 27712855Sgabeblack@google.com#define exs_v_swc 0 27812855Sgabeblack@google.com#define exs_v_inv 1 27912855Sgabeblack@google.com#define exs_v_dze 2 28012855Sgabeblack@google.com#define exs_v_fov 3 28112855Sgabeblack@google.com#define exs_v_unf 4 28212855Sgabeblack@google.com#define exs_v_ine 5 28312855Sgabeblack@google.com#define exs_v_iov 6 28412855Sgabeblack@google.com 28512855Sgabeblack@google.com#define exs_m_swc (1<<exs_v_swc) 28612855Sgabeblack@google.com#define exs_m_inv (1<<exs_v_inv) 28712855Sgabeblack@google.com#define exs_m_dze (1<<exs_v_dze) 28812855Sgabeblack@google.com#define exs_m_fov (1<<exs_v_fov) 28912855Sgabeblack@google.com#define exs_m_unf (1<<exs_v_unf) 29012855Sgabeblack@google.com#define exs_m_ine (1<<exs_v_ine) 29112855Sgabeblack@google.com#define exs_m_iov (1<<exs_v_iov) 29212855Sgabeblack@google.com 29312855Sgabeblack@google.com// 29412855Sgabeblack@google.com// machine check error summary register (mces) 29512855Sgabeblack@google.com// 29612855Sgabeblack@google.com// mces_v_mchk <0> ; machine check in progress 29712855Sgabeblack@google.com// mces_v_sce <1> ; system correctable error 29812855Sgabeblack@google.com// mces_v_pce <2> ; processor correctable error 29912855Sgabeblack@google.com// mces_v_dpc <3> ; disable reporting of processor correctable errors 30012855Sgabeblack@google.com// mces_v_dsc <4> ; disable reporting of system correctable errors 30112855Sgabeblack@google.com#define mces_v_mchk 0 30212855Sgabeblack@google.com#define mces_v_sce 1 30312855Sgabeblack@google.com#define mces_v_pce 2 30412855Sgabeblack@google.com#define mces_v_dpc 3 30512855Sgabeblack@google.com#define mces_v_dsc 4 30612855Sgabeblack@google.com 30712855Sgabeblack@google.com#define mces_m_mchk (1<<mces_v_mchk) 30812855Sgabeblack@google.com#define mces_m_sce (1<<mces_v_sce) 30912855Sgabeblack@google.com#define mces_m_pce (1<<mces_v_pce) 31012855Sgabeblack@google.com#define mces_m_dpc (1<<mces_v_dpc) 31112855Sgabeblack@google.com#define mces_m_dsc (1<<mces_v_dsc) 31212855Sgabeblack@google.com#define mces_m_all ((1<<mces_v_mchk) | (1<<mces_v_sce) | (1<<mces_v_pce) | (1<<mces_v_dpc) | (1<<mces_v_dsc)) 31312855Sgabeblack@google.com 31412855Sgabeblack@google.com#endif 31512855Sgabeblack@google.com