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