regnum.h revision 1.1 1 1.1 jonathan /* $NetBSD: regnum.h,v 1.1 1995/12/20 02:00:28 jonathan Exp $ */
2 1.1 jonathan
3 1.1 jonathan /*
4 1.1 jonathan * Copyright (c) 1988 University of Utah.
5 1.1 jonathan * Copyright (c) 1992, 1993
6 1.1 jonathan * The Regents of the University of California. All rights reserved.
7 1.1 jonathan *
8 1.1 jonathan * This code is derived from software contributed to Berkeley by
9 1.1 jonathan * the Systems Programming Group of the University of Utah Computer
10 1.1 jonathan * Science Department and Ralph Campbell.
11 1.1 jonathan *
12 1.1 jonathan * Redistribution and use in source and binary forms, with or without
13 1.1 jonathan * modification, are permitted provided that the following conditions
14 1.1 jonathan * are met:
15 1.1 jonathan * 1. Redistributions of source code must retain the above copyright
16 1.1 jonathan * notice, this list of conditions and the following disclaimer.
17 1.1 jonathan * 2. Redistributions in binary form must reproduce the above copyright
18 1.1 jonathan * notice, this list of conditions and the following disclaimer in the
19 1.1 jonathan * documentation and/or other materials provided with the distribution.
20 1.1 jonathan * 3. All advertising materials mentioning features or use of this software
21 1.1 jonathan * must display the following acknowledgement:
22 1.1 jonathan * This product includes software developed by the University of
23 1.1 jonathan * California, Berkeley and its contributors.
24 1.1 jonathan * 4. Neither the name of the University nor the names of its contributors
25 1.1 jonathan * may be used to endorse or promote products derived from this software
26 1.1 jonathan * without specific prior written permission.
27 1.1 jonathan *
28 1.1 jonathan * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
29 1.1 jonathan * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
30 1.1 jonathan * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
31 1.1 jonathan * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
32 1.1 jonathan * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
33 1.1 jonathan * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
34 1.1 jonathan * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
35 1.1 jonathan * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
36 1.1 jonathan * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
37 1.1 jonathan * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
38 1.1 jonathan * SUCH DAMAGE.
39 1.1 jonathan *
40 1.1 jonathan * from: Utah Hdr: reg.h 1.1 90/07/09
41 1.1 jonathan *
42 1.1 jonathan * @(#)reg.h 8.2 (Berkeley) 1/11/94
43 1.1 jonathan */
44 1.1 jonathan
45 1.1 jonathan /*
46 1.1 jonathan * Location of the users' stored
47 1.1 jonathan * registers relative to ZERO.
48 1.1 jonathan * Usage is p->p_regs[XX].
49 1.1 jonathan */
50 1.1 jonathan #define ZERO 0
51 1.1 jonathan #define AST 1
52 1.1 jonathan #define V0 2
53 1.1 jonathan #define V1 3
54 1.1 jonathan #define A0 4
55 1.1 jonathan #define A1 5
56 1.1 jonathan #define A2 6
57 1.1 jonathan #define A3 7
58 1.1 jonathan #define T0 8
59 1.1 jonathan #define T1 9
60 1.1 jonathan #define T2 10
61 1.1 jonathan #define T3 11
62 1.1 jonathan #define T4 12
63 1.1 jonathan #define T5 13
64 1.1 jonathan #define T6 14
65 1.1 jonathan #define T7 15
66 1.1 jonathan #define S0 16
67 1.1 jonathan #define S1 17
68 1.1 jonathan #define S2 18
69 1.1 jonathan #define S3 19
70 1.1 jonathan #define S4 20
71 1.1 jonathan #define S5 21
72 1.1 jonathan #define S6 22
73 1.1 jonathan #define S7 23
74 1.1 jonathan #define T8 24
75 1.1 jonathan #define T9 25
76 1.1 jonathan #define K0 26
77 1.1 jonathan #define K1 27
78 1.1 jonathan #define GP 28
79 1.1 jonathan #define SP 29
80 1.1 jonathan #define S8 30
81 1.1 jonathan #define RA 31
82 1.1 jonathan #define SR 32
83 1.1 jonathan #define PS SR /* alias for SR */
84 1.1 jonathan #define MULLO 33
85 1.1 jonathan #define MULHI 34
86 1.1 jonathan #define BADVADDR 35
87 1.1 jonathan #define CAUSE 36
88 1.1 jonathan #define PC 37
89 1.1 jonathan
90 1.1 jonathan #define FPBASE 38
91 1.1 jonathan #define F0 (FPBASE+0)
92 1.1 jonathan #define F1 (FPBASE+1)
93 1.1 jonathan #define F2 (FPBASE+2)
94 1.1 jonathan #define F3 (FPBASE+3)
95 1.1 jonathan #define F4 (FPBASE+4)
96 1.1 jonathan #define F5 (FPBASE+5)
97 1.1 jonathan #define F6 (FPBASE+6)
98 1.1 jonathan #define F7 (FPBASE+7)
99 1.1 jonathan #define F8 (FPBASE+8)
100 1.1 jonathan #define F9 (FPBASE+9)
101 1.1 jonathan #define F10 (FPBASE+10)
102 1.1 jonathan #define F11 (FPBASE+11)
103 1.1 jonathan #define F12 (FPBASE+12)
104 1.1 jonathan #define F13 (FPBASE+13)
105 1.1 jonathan #define F14 (FPBASE+14)
106 1.1 jonathan #define F15 (FPBASE+15)
107 1.1 jonathan #define F16 (FPBASE+16)
108 1.1 jonathan #define F17 (FPBASE+17)
109 1.1 jonathan #define F18 (FPBASE+18)
110 1.1 jonathan #define F19 (FPBASE+19)
111 1.1 jonathan #define F20 (FPBASE+20)
112 1.1 jonathan #define F21 (FPBASE+21)
113 1.1 jonathan #define F22 (FPBASE+22)
114 1.1 jonathan #define F23 (FPBASE+23)
115 1.1 jonathan #define F24 (FPBASE+24)
116 1.1 jonathan #define F25 (FPBASE+25)
117 1.1 jonathan #define F26 (FPBASE+26)
118 1.1 jonathan #define F27 (FPBASE+27)
119 1.1 jonathan #define F28 (FPBASE+28)
120 1.1 jonathan #define F29 (FPBASE+29)
121 1.1 jonathan #define F30 (FPBASE+30)
122 1.1 jonathan #define F31 (FPBASE+31)
123 1.1 jonathan #define FSR (FPBASE+32)
124 1.1 jonathan
125 1.1 jonathan #ifdef IPCREG
126 1.1 jonathan #define NIPCREG (FSR + 1)
127 1.1 jonathan int ipcreg[NIPCREG] = {
128 1.1 jonathan ZERO, AST, V0, V1, A0, A1, A2, A3, T0, T1, T2, T3, T4, T5, T6, T7,
129 1.1 jonathan S0, S1, S2, S3, S4, S5, S6, S7, T8, T9, K0, K1, GP, SP, S8, RA,
130 1.1 jonathan SR, MULLO, MULHI, BADVADDR, CAUSE, PC,
131 1.1 jonathan F0, F1, F2, F3, F4, F5, F6, F7,
132 1.1 jonathan F8, F9, F10, F11, F12, F13, F14, F15,
133 1.1 jonathan F16, F17, F18, F19, F20, F21, F22, F23,
134 1.1 jonathan F24, F25, F26, F27, F28, F29, F30, F31, FSR,
135 1.1 jonathan };
136 1.1 jonathan #endif
137 1.1 jonathan
138 1.1 jonathan #ifdef LANGUAGE_C
139 1.1 jonathan /*
140 1.1 jonathan * Register set accessible via /proc/$pid/reg
141 1.1 jonathan */
142 1.1 jonathan struct reg {
143 1.1 jonathan int r_regs[71]; /* numbered as above */
144 1.1 jonathan };
145 1.1 jonathan #endif /* LANGUAGE_C */
146