xref: /f-stack/freebsd/mips/include/regnum.h (revision 22ce4aff)
1a9643ea8Slogwang /*	$OpenBSD: regnum.h,v 1.3 1999/01/27 04:46:06 imp Exp $	*/
2a9643ea8Slogwang 
3a9643ea8Slogwang /*-
4*22ce4affSfengbojiang  * SPDX-License-Identifier: BSD-3-Clause
5*22ce4affSfengbojiang  *
6a9643ea8Slogwang  * Copyright (c) 1988 University of Utah.
7a9643ea8Slogwang  * Copyright (c) 1992, 1993
8a9643ea8Slogwang  *	The Regents of the University of California.  All rights reserved.
9a9643ea8Slogwang  *
10a9643ea8Slogwang  * This code is derived from software contributed to Berkeley by
11a9643ea8Slogwang  * the Systems Programming Group of the University of Utah Computer
12a9643ea8Slogwang  * Science Department and Ralph Campbell.
13a9643ea8Slogwang  *
14a9643ea8Slogwang  * Redistribution and use in source and binary forms, with or without
15a9643ea8Slogwang  * modification, are permitted provided that the following conditions
16a9643ea8Slogwang  * are met:
17a9643ea8Slogwang  * 1. Redistributions of source code must retain the above copyright
18a9643ea8Slogwang  *    notice, this list of conditions and the following disclaimer.
19a9643ea8Slogwang  * 2. Redistributions in binary form must reproduce the above copyright
20a9643ea8Slogwang  *    notice, this list of conditions and the following disclaimer in the
21a9643ea8Slogwang  *    documentation and/or other materials provided with the distribution.
22*22ce4affSfengbojiang  * 3. Neither the name of the University nor the names of its contributors
23a9643ea8Slogwang  *    may be used to endorse or promote products derived from this software
24a9643ea8Slogwang  *    without specific prior written permission.
25a9643ea8Slogwang  *
26a9643ea8Slogwang  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
27a9643ea8Slogwang  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
28a9643ea8Slogwang  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
29a9643ea8Slogwang  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
30a9643ea8Slogwang  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
31a9643ea8Slogwang  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
32a9643ea8Slogwang  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
33a9643ea8Slogwang  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
34a9643ea8Slogwang  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
35a9643ea8Slogwang  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
36a9643ea8Slogwang  * SUCH DAMAGE.
37a9643ea8Slogwang  *
38a9643ea8Slogwang  *	from: Utah Hdr: reg.h 1.1 90/07/09
39a9643ea8Slogwang  *	@(#)reg.h	8.2 (Berkeley) 1/11/94
40a9643ea8Slogwang  *	JNPR: regnum.h,v 1.6 2007/08/09 11:23:32 katta
41a9643ea8Slogwang  * $FreeBSD$
42a9643ea8Slogwang  */
43a9643ea8Slogwang 
44a9643ea8Slogwang #ifndef _MACHINE_REGNUM_H_
45a9643ea8Slogwang #define	_MACHINE_REGNUM_H_
46a9643ea8Slogwang 
47*22ce4affSfengbojiang #define	NUMSAVEREGS	40
48*22ce4affSfengbojiang #define	NUMFPREGS	34
49*22ce4affSfengbojiang 
50a9643ea8Slogwang /*
51a9643ea8Slogwang  * Location of the saved registers relative to ZERO.
52a9643ea8Slogwang  * This must match struct trapframe defined in frame.h exactly.
53a9643ea8Slogwang  * This must also match regdef.h.
54a9643ea8Slogwang  */
55*22ce4affSfengbojiang #if defined(_KERNEL) || defined(_WANT_MIPS_REGNUM)
56a9643ea8Slogwang #define	ZERO	0
57a9643ea8Slogwang #define	AST	1
58a9643ea8Slogwang #define	V0	2
59a9643ea8Slogwang #define	V1	3
60a9643ea8Slogwang #define	A0	4
61a9643ea8Slogwang #define	A1	5
62a9643ea8Slogwang #define	A2	6
63a9643ea8Slogwang #define	A3	7
64a9643ea8Slogwang #if defined(__mips_n32) || defined(__mips_n64)
65a9643ea8Slogwang #define	A4	8
66a9643ea8Slogwang #define	A5	9
67a9643ea8Slogwang #define	A6	10
68a9643ea8Slogwang #define	A7	11
69a9643ea8Slogwang #define	T0	12
70a9643ea8Slogwang #define	T1	13
71a9643ea8Slogwang #define	T2	14
72a9643ea8Slogwang #define	T3	15
73a9643ea8Slogwang #else
74a9643ea8Slogwang #define	T0	8
75a9643ea8Slogwang #define	T1	9
76a9643ea8Slogwang #define	T2	10
77a9643ea8Slogwang #define	T3	11
78a9643ea8Slogwang #define	T4	12
79a9643ea8Slogwang #define	T5	13
80a9643ea8Slogwang #define	T6	14
81a9643ea8Slogwang #define	T7	15
82a9643ea8Slogwang #endif
83a9643ea8Slogwang #define	S0	16
84a9643ea8Slogwang #define	S1	17
85a9643ea8Slogwang #define	S2	18
86a9643ea8Slogwang #define	S3	19
87a9643ea8Slogwang #define	S4	20
88a9643ea8Slogwang #define	S5	21
89a9643ea8Slogwang #define	S6	22
90a9643ea8Slogwang #define	S7	23
91a9643ea8Slogwang #define	T8	24
92a9643ea8Slogwang #define	T9	25
93a9643ea8Slogwang #define	K0	26
94a9643ea8Slogwang #define	K1	27
95a9643ea8Slogwang #define	GP	28
96a9643ea8Slogwang #define	SP	29
97a9643ea8Slogwang #define	S8	30
98a9643ea8Slogwang #define	RA	31
99a9643ea8Slogwang #define	SR	32
100a9643ea8Slogwang #define	PS	SR	/* alias for SR */
101a9643ea8Slogwang #define	MULLO	33
102a9643ea8Slogwang #define	MULHI	34
103a9643ea8Slogwang #define	BADVADDR 35
104a9643ea8Slogwang #define	CAUSE	36
105a9643ea8Slogwang #define	PC	37
106a9643ea8Slogwang /*
107a9643ea8Slogwang  * IC is valid only on RM7K and RM9K processors. Access to this is
108a9643ea8Slogwang  * controlled by IC_INT_REG which defined in kernel config
109a9643ea8Slogwang  */
110a9643ea8Slogwang #define	IC	38
111a9643ea8Slogwang #define	DUMMY	39	/* for 8 byte alignment */
112a9643ea8Slogwang 
113a9643ea8Slogwang /*
114a9643ea8Slogwang  * Pseudo registers so we save a complete set of registers regardless of
115a9643ea8Slogwang  * the ABI. See regdef.h for a more complete explanation.
116a9643ea8Slogwang  */
117a9643ea8Slogwang #if defined(__mips_n32) || defined(__mips_n64)
118a9643ea8Slogwang #define	TA0	8
119a9643ea8Slogwang #define	TA1	9
120a9643ea8Slogwang #define	TA2	10
121a9643ea8Slogwang #define	TA3	11
122a9643ea8Slogwang #else
123a9643ea8Slogwang #define	TA0	12
124a9643ea8Slogwang #define	TA1	13
125a9643ea8Slogwang #define	TA2	14
126a9643ea8Slogwang #define	TA3	15
127a9643ea8Slogwang #endif
128a9643ea8Slogwang 
129a9643ea8Slogwang /*
130a9643ea8Slogwang  * Index of FP registers in 'struct frame', counting from the beginning
131a9643ea8Slogwang  * of the frame (i.e., including the general registers).
132a9643ea8Slogwang  */
133a9643ea8Slogwang #define	FPBASE	NUMSAVEREGS
134a9643ea8Slogwang #define	F0	(FPBASE+0)
135a9643ea8Slogwang #define	F1	(FPBASE+1)
136a9643ea8Slogwang #define	F2	(FPBASE+2)
137a9643ea8Slogwang #define	F3	(FPBASE+3)
138a9643ea8Slogwang #define	F4	(FPBASE+4)
139a9643ea8Slogwang #define	F5	(FPBASE+5)
140a9643ea8Slogwang #define	F6	(FPBASE+6)
141a9643ea8Slogwang #define	F7	(FPBASE+7)
142a9643ea8Slogwang #define	F8	(FPBASE+8)
143a9643ea8Slogwang #define	F9	(FPBASE+9)
144a9643ea8Slogwang #define	F10	(FPBASE+10)
145a9643ea8Slogwang #define	F11	(FPBASE+11)
146a9643ea8Slogwang #define	F12	(FPBASE+12)
147a9643ea8Slogwang #define	F13	(FPBASE+13)
148a9643ea8Slogwang #define	F14	(FPBASE+14)
149a9643ea8Slogwang #define	F15	(FPBASE+15)
150a9643ea8Slogwang #define	F16	(FPBASE+16)
151a9643ea8Slogwang #define	F17	(FPBASE+17)
152a9643ea8Slogwang #define	F18	(FPBASE+18)
153a9643ea8Slogwang #define	F19	(FPBASE+19)
154a9643ea8Slogwang #define	F20	(FPBASE+20)
155a9643ea8Slogwang #define	F21	(FPBASE+21)
156a9643ea8Slogwang #define	F22	(FPBASE+22)
157a9643ea8Slogwang #define	F23	(FPBASE+23)
158a9643ea8Slogwang #define	F24	(FPBASE+24)
159a9643ea8Slogwang #define	F25	(FPBASE+25)
160a9643ea8Slogwang #define	F26	(FPBASE+26)
161a9643ea8Slogwang #define	F27	(FPBASE+27)
162a9643ea8Slogwang #define	F28	(FPBASE+28)
163a9643ea8Slogwang #define	F29	(FPBASE+29)
164a9643ea8Slogwang #define	F30	(FPBASE+30)
165a9643ea8Slogwang #define	F31	(FPBASE+31)
166a9643ea8Slogwang #define	FSR	(FPBASE+32)
167*22ce4affSfengbojiang #define FIR	(FPBASE+33)
168a9643ea8Slogwang 
169a9643ea8Slogwang /*
170a9643ea8Slogwang  * Index of FP registers in 'struct frame', relative to the base
171a9643ea8Slogwang  * of the FP registers in frame (i.e., *not* including the general
172a9643ea8Slogwang  * registers).
173a9643ea8Slogwang  */
174a9643ea8Slogwang #define	F0_NUM	(0)
175a9643ea8Slogwang #define	F1_NUM	(1)
176a9643ea8Slogwang #define	F2_NUM	(2)
177a9643ea8Slogwang #define	F3_NUM	(3)
178a9643ea8Slogwang #define	F4_NUM	(4)
179a9643ea8Slogwang #define	F5_NUM	(5)
180a9643ea8Slogwang #define	F6_NUM	(6)
181a9643ea8Slogwang #define	F7_NUM	(7)
182a9643ea8Slogwang #define	F8_NUM	(8)
183a9643ea8Slogwang #define	F9_NUM	(9)
184a9643ea8Slogwang #define	F10_NUM	(10)
185a9643ea8Slogwang #define	F11_NUM	(11)
186a9643ea8Slogwang #define	F12_NUM	(12)
187a9643ea8Slogwang #define	F13_NUM	(13)
188a9643ea8Slogwang #define	F14_NUM	(14)
189a9643ea8Slogwang #define	F15_NUM	(15)
190a9643ea8Slogwang #define	F16_NUM	(16)
191a9643ea8Slogwang #define	F17_NUM	(17)
192a9643ea8Slogwang #define	F18_NUM	(18)
193a9643ea8Slogwang #define	F19_NUM	(19)
194a9643ea8Slogwang #define	F20_NUM	(20)
195a9643ea8Slogwang #define	F21_NUM	(21)
196a9643ea8Slogwang #define	F22_NUM	(22)
197a9643ea8Slogwang #define	F23_NUM	(23)
198a9643ea8Slogwang #define	F24_NUM	(24)
199a9643ea8Slogwang #define	F25_NUM	(25)
200a9643ea8Slogwang #define	F26_NUM	(26)
201a9643ea8Slogwang #define	F27_NUM	(27)
202a9643ea8Slogwang #define	F28_NUM	(28)
203a9643ea8Slogwang #define	F29_NUM	(29)
204a9643ea8Slogwang #define	F30_NUM	(30)
205a9643ea8Slogwang #define	F31_NUM	(31)
206a9643ea8Slogwang #define	FSR_NUM	(32)
207*22ce4affSfengbojiang #define	FIR_NUM	(33)
208*22ce4affSfengbojiang 
209*22ce4affSfengbojiang #endif	/* _KERNEL || _WANT_MIPS_REGNUM */
210a9643ea8Slogwang 
211a9643ea8Slogwang #endif /* !_MACHINE_REGNUM_H_ */
212