314 lines
8.9 KiB
C
314 lines
8.9 KiB
C
/*
|
|
* 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_ALPHA_DEFS_INCLUDED
|
|
#define EV5_ALPHA_DEFS_INCLUDED 1
|
|
|
|
// from ev5_alpha_defs.mar from Lance's fetch directory
|
|
// Lower-caseified and $ signs removed ... pb Nov/95
|
|
|
|
//
|
|
// PS Layout - PS
|
|
// Loc Size name function
|
|
// ------ ------ ______ -----------------------------------
|
|
// <31:29> 3 SA stack alignment
|
|
// <31:13> 24 RES Reserved MBZ
|
|
// <12:8> 5 IPL Priority level
|
|
// <7> 1 VMM Virtual Mach Monitor
|
|
// <6:5> 2 RES Reserved MBZ
|
|
// <4:3> 2 CM Current Mode
|
|
// <2> 1 IP Interrupt Pending
|
|
// <1:0> 2 SW Software bits
|
|
//
|
|
|
|
#define ps_v_sw 0
|
|
#define ps_m_sw (3<<ps_v_sw)
|
|
|
|
#define ps_v_ip 2
|
|
#define ps_m_ip (1<<ps_v_ip)
|
|
|
|
#define ps_v_cm 3
|
|
#define ps_m_cm (3<<ps_v_cm)
|
|
|
|
#define ps_v_vmm 7
|
|
#define ps_m_vmm (1<<ps_v_vmm)
|
|
|
|
#define ps_v_ipl 8
|
|
#define ps_m_ipl (0x1f<<ps_v_ipl)
|
|
|
|
#define ps_v_sp (0x38)
|
|
#define ps_m_sp (0x3f<<ps_v_sp)
|
|
|
|
|
|
#define ps_c_kern (0x00)
|
|
#define ps_c_exec (0x08)
|
|
#define ps_c_supr (0x10)
|
|
#define ps_c_user (0x18)
|
|
#define ps_c_ipl0 (0x0000)
|
|
#define ps_c_ipl1 (0x0100)
|
|
#define ps_c_ipl2 (0x0200)
|
|
#define ps_c_ipl3 (0x0300)
|
|
#define ps_c_ipl4 (0x0400)
|
|
#define ps_c_ipl5 (0x0500)
|
|
#define ps_c_ipl6 (0x0600)
|
|
#define ps_c_ipl7 (0x0700)
|
|
#define ps_c_ipl8 (0x0800)
|
|
#define ps_c_ipl9 (0x0900)
|
|
#define ps_c_ipl10 (0x0A00)
|
|
#define ps_c_ipl11 (0x0B00)
|
|
#define ps_c_ipl12 (0x0C00)
|
|
#define ps_c_ipl13 (0x0D00)
|
|
#define ps_c_ipl14 (0x0E00)
|
|
#define ps_c_ipl15 (0x0F00)
|
|
#define ps_c_ipl16 (0x1000)
|
|
#define ps_c_ipl17 (0x1100)
|
|
#define ps_c_ipl18 (0x1200)
|
|
#define ps_c_ipl19 (0x1300)
|
|
#define ps_c_ipl20 (0x1400)
|
|
#define ps_c_ipl21 (0x1500)
|
|
#define ps_c_ipl22 (0x1600)
|
|
#define ps_c_ipl23 (0x1700)
|
|
#define ps_c_ipl24 (0x1800)
|
|
#define ps_c_ipl25 (0x1900)
|
|
#define ps_c_ipl26 (0x1A00)
|
|
#define ps_c_ipl27 (0x1B00)
|
|
#define ps_c_ipl28 (0x1C00)
|
|
#define ps_c_ipl29 (0x1D00)
|
|
#define ps_c_ipl30 (0x1E00)
|
|
#define ps_c_ipl31 (0x1F00)
|
|
|
|
//
|
|
// PTE layout - symbol prefix PTE_
|
|
//
|
|
// Loc Size name function
|
|
// ------ ------ ------ -----------------------------------
|
|
// <63:32> 32 PFN Page Frame Number
|
|
// <31:16> 16 SOFT Bits reserved for software use
|
|
// <15> 1 UWE User write enable
|
|
// <14> 1 SWE Super write enable
|
|
// <13> 1 EWE Exec write enable
|
|
// <12> 1 KWE Kernel write enable
|
|
// <11> 1 URE User read enable
|
|
// <10> 1 SRE Super read enable
|
|
// <9> 1 ERE Exec read enable
|
|
// <8> 1 KRE Kernel read enable
|
|
// <7:6> 2 RES Reserved SBZ
|
|
// <5> 1 HPF Huge Page Flag
|
|
// <4> 1 ASM Wild card address space number match
|
|
// <3> 1 FOE Fault On execute
|
|
// <2> 1 FOW Fault On Write
|
|
// <1> 1 FOR Fault On Read
|
|
// <0> 1 V valid bit
|
|
//
|
|
|
|
#define pte_v_pfn 32
|
|
#define pte_m_soft (0xFFFF0000)
|
|
#define pte_v_soft 16
|
|
#define pte_m_uwe (0x8000)
|
|
#define pte_v_uwe 15
|
|
#define pte_m_swe (0x4000)
|
|
#define pte_v_swe 14
|
|
#define pte_m_ewe (0x2000)
|
|
#define pte_v_ewe 13
|
|
#define pte_m_kwe (0x1000)
|
|
#define pte_v_kwe 12
|
|
#define pte_m_ure (0x0800)
|
|
#define pte_v_ure 11
|
|
#define pte_m_sre (0x0400)
|
|
#define pte_v_sre 10
|
|
#define pte_m_ere (0x0200)
|
|
#define pte_v_ere 9
|
|
#define pte_m_kre (0x0100)
|
|
#define pte_v_kre 8
|
|
#define pte_m_hpf (0x0020)
|
|
#define pte_v_hpf 5
|
|
#define pte_m_asm (0x0010)
|
|
#define pte_v_asm 4
|
|
#define pte_m_foe (0x0008)
|
|
#define pte_v_foe 3
|
|
#define pte_m_fow (0x0004)
|
|
#define pte_v_fow 2
|
|
#define pte_m_for (0x0002)
|
|
#define pte_v_for 1
|
|
#define pte_m_v (0x0001)
|
|
#define pte_v_v 0
|
|
|
|
//
|
|
// VA layout - symbol prefix VA_
|
|
//
|
|
// Loc Size name function
|
|
// ------ ------ ------- -----------------------------------
|
|
// <42:33> 10 SEG1 First seg table offset for mapping
|
|
// <32:23> 10 SEG2 Second seg table offset for mapping
|
|
// <22:13> 10 SEG3 Third seg table offset for mapping
|
|
// <12:0> 13 OFFSET Byte within page
|
|
//
|
|
|
|
#define va_m_offset (0x000000001FFF)
|
|
#define va_v_offset 0
|
|
#define va_m_seg3 (0x0000007FE000)
|
|
#define va_v_seg3 13
|
|
#define va_m_seg2 (0x0001FF800000)
|
|
#define va_v_seg2 23
|
|
#define va_m_seg1 (0x7FE00000000)
|
|
#define va_v_seg1 33
|
|
|
|
//
|
|
//PRIVILEGED CONTEXT BLOCK (PCB)
|
|
//
|
|
#define pcb_q_ksp 0
|
|
#define pcb_q_esp 8
|
|
#define pcb_q_ssp 16
|
|
#define pcb_q_usp 24
|
|
#define pcb_q_ptbr 32
|
|
#define pcb_q_asn 40
|
|
#define pcb_q_ast 48
|
|
#define pcb_q_fen 56
|
|
#define pcb_q_cc 64
|
|
#define pcb_q_unq 72
|
|
#define pcb_q_sct 80
|
|
|
|
#define pcb_v_asten 0
|
|
#define pcb_m_asten (0x0f<<pcb_v_asten)
|
|
#define pcb_v_astsr 4
|
|
#define pcb_m_astsr (0x0f<<pcb_v_astsr)
|
|
#define pcb_v_dat 63
|
|
#define pcb_v_pme 62
|
|
|
|
//
|
|
// SYSTEM CONTROL BLOCK (SCB)
|
|
//
|
|
|
|
#define scb_v_fen (0x0010)
|
|
#define scb_v_acv (0x0080)
|
|
#define scb_v_tnv (0x0090)
|
|
#define scb_v_for (0x00A0)
|
|
#define scb_v_fow (0x00B0)
|
|
#define scb_v_foe (0x00C0)
|
|
#define scb_v_arith (0x0200)
|
|
#define scb_v_kast (0x0240)
|
|
#define scb_v_east (0x0250)
|
|
#define scb_v_sast (0x0260)
|
|
#define scb_v_uast (0x0270)
|
|
#define scb_v_unalign (0x0280)
|
|
#define scb_v_bpt (0x0400)
|
|
#define scb_v_bugchk (0x0410)
|
|
#define scb_v_opcdec (0x0420)
|
|
#define scb_v_illpal (0x0430)
|
|
#define scb_v_trap (0x0440)
|
|
#define scb_v_chmk (0x0480)
|
|
#define scb_v_chme (0x0490)
|
|
#define scb_v_chms (0x04A0)
|
|
#define scb_v_chmu (0x04B0)
|
|
#define scb_v_sw0 (0x0500)
|
|
#define scb_v_sw1 (0x0510)
|
|
#define scb_v_sw2 (0x0520)
|
|
#define scb_v_sw3 (0x0530)
|
|
#define scb_v_sw4 (0x0540)
|
|
#define scb_v_sw5 (0x0550)
|
|
#define scb_v_sw6 (0x0560)
|
|
#define scb_v_sw7 (0x0570)
|
|
#define scb_v_sw8 (0x0580)
|
|
#define scb_v_sw9 (0x0590)
|
|
#define scb_v_sw10 (0x05A0)
|
|
#define scb_v_sw11 (0x05B0)
|
|
#define scb_v_sw12 (0x05C0)
|
|
#define scb_v_sw13 (0x05D0)
|
|
#define scb_v_sw14 (0x05E0)
|
|
#define scb_v_sw15 (0x05F0)
|
|
#define scb_v_clock (0x0600)
|
|
#define scb_v_inter (0x0610)
|
|
#define scb_v_sys_corr_err (0x0620)
|
|
#define scb_v_proc_corr_err (0x0630)
|
|
#define scb_v_pwrfail (0x0640)
|
|
#define scb_v_perfmon (0x0650)
|
|
#define scb_v_sysmchk (0x0660)
|
|
#define scb_v_procmchk (0x0670)
|
|
#define scb_v_passive_rel (0x06F0)
|
|
|
|
//
|
|
// Stack frame (FRM)
|
|
//
|
|
|
|
#define frm_v_r2 (0x0000)
|
|
#define frm_v_r3 (0x0008)
|
|
#define frm_v_r4 (0x0010)
|
|
#define frm_v_r5 (0x0018)
|
|
#define frm_v_r6 (0x0020)
|
|
#define frm_v_r7 (0x0028)
|
|
#define frm_v_pc (0x0030)
|
|
#define frm_v_ps (0x0038)
|
|
|
|
//
|
|
// Exeception summary register (EXS)
|
|
//
|
|
// exs_v_swc <0> ; Software completion
|
|
// exs_v_inv <1> ; Ivalid operation
|
|
// exs_v_dze <2> ; Div by zero
|
|
// exs_v_fov <3> ; Floating point overflow
|
|
// exs_v_unf <4> ; Floating point underflow
|
|
// exs_v_ine <5> ; Floating point inexact
|
|
// exs_v_iov <6> ; Floating convert to integer overflow
|
|
#define exs_v_swc 0
|
|
#define exs_v_inv 1
|
|
#define exs_v_dze 2
|
|
#define exs_v_fov 3
|
|
#define exs_v_unf 4
|
|
#define exs_v_ine 5
|
|
#define exs_v_iov 6
|
|
|
|
#define exs_m_swc (1<<exs_v_swc)
|
|
#define exs_m_inv (1<<exs_v_inv)
|
|
#define exs_m_dze (1<<exs_v_dze)
|
|
#define exs_m_fov (1<<exs_v_fov)
|
|
#define exs_m_unf (1<<exs_v_unf)
|
|
#define exs_m_ine (1<<exs_v_ine)
|
|
#define exs_m_iov (1<<exs_v_iov)
|
|
|
|
//
|
|
// machine check error summary register (mces)
|
|
//
|
|
// mces_v_mchk <0> ; machine check in progress
|
|
// mces_v_sce <1> ; system correctable error
|
|
// mces_v_pce <2> ; processor correctable error
|
|
// mces_v_dpc <3> ; disable reporting of processor correctable errors
|
|
// mces_v_dsc <4> ; disable reporting of system correctable errors
|
|
#define mces_v_mchk 0
|
|
#define mces_v_sce 1
|
|
#define mces_v_pce 2
|
|
#define mces_v_dpc 3
|
|
#define mces_v_dsc 4
|
|
|
|
#define mces_m_mchk (1<<mces_v_mchk)
|
|
#define mces_m_sce (1<<mces_v_sce)
|
|
#define mces_m_pce (1<<mces_v_pce)
|
|
#define mces_m_dpc (1<<mces_v_dpc)
|
|
#define mces_m_dsc (1<<mces_v_dsc)
|
|
#define mces_m_all ((1<<mces_v_mchk) | (1<<mces_v_sce) | (1<<mces_v_pce) | (1<<mces_v_dpc) | (1<<mces_v_dsc))
|
|
|
|
#endif
|