1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
|
/* $OpenBSD: sid.h,v 1.10 2001/03/16 22:46:25 hugh Exp $ */
/* $NetBSD: sid.h,v 1.12 1999/12/11 17:55:13 ragge Exp $ */
/*
* Copyright (c) 1994 Ludd, University of Lule}, Sweden.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. 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.
* 3. All advertising materials mentioning features or use of this software
* must display the following acknowledgement:
* This product includes software developed at Ludd, University of Lule}.
* 4. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 AUTHOR 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.
*/
/*
* Board-Type (?_BTYP_?) and Sub-Type (?_STYP_?) are synonima.
* Michael Kukat changed this 01/27/2001, STYP is relly a subtype now.
* other synonima are:
*/
#define cpudata vax_cpudata
#define cputype vax_cputype
#define cpusubtype vax_boardtype
/*
* Chip CPU types / chip CPU Subtypes
*
* The type of a VAX is given by the high-order byte of the System
* identification register (SID) and describes families or series of VAXen.
* Board-Types/Sub-Types within series are described by the SIED register.
*/
/*
* 700 series (1977)
*/
#define VAX_TYP_780 1 /* VAX-11/780, 785, 782 */
#define VAX_TYP_750 2 /* VAX-11/750 */
#define VAX_TYP_730 3 /* VAX-11/730, 725 */
#define VAX_TYP_790 4 /* VAX 8600, 8650 */
#define VAX_BTYP_780 0x01000000 /* generic 11/780 */
#define VAX_BTYP_750 0x02000000 /* generic 11/750 */
#define VAX_BTYP_730 0x03000000 /* generic 11/730 */
#define VAX_BTYP_790 0x04000000 /* generic 11/790 */
/*
* 8000 series (1986)
*/
#define VAX_TYP_8SS 5 /* VAX 8200, 8300, 8250, 8350, VS 8000 */
#define VAX_TYP_8NN 6 /* VAX 8530, 8550, 8700, 8800 */
#define VAX_BTYP_8000 0x05000000 /* generic VAX 8000 */
#define VAX_BTYP_8800 0x06000000 /* generic Nautilus */
#define VAX_BTYP_8700 0x06000001
#define VAX_BTYP_8550 0x06000006
#define VAX_BTYP_8500 0x06000007
/*
* MicroVAX I (1984)
*/
#define VAX_TYP_UV1 7 /* MicroVAX I, VAXstation I */
/* VAX_TYP_610 7 */
#define VAX_BTYP_610 0x07000000 /* generic MicroVAX-I */
/*
* MicroVAX II series (1985)
*/
#define VAX_TYP_UV2 8
/* VAX_TYP_78032 8 */
#define VAX_BTYP_630 0x08000001 /* MicroVAX II, VAXstation II */
#define VAX_BTYP_410 0x08000004 /* MicroVAX 2000, VAXstation 2000 */
/*
* CVAX chip series (1987)
*/
#define VAX_TYP_CVAX 10
/* VAX_TYP_650 10 */
#define VAX_BTYP_650 0x0A000001 /* MicroVAX 3500, 3600 */
/* VAX_BTYP_65D 0x0A000001 VAXstation 3200, 3500 XXX */
/* VAX_BTYP_640 0x0A000001 MicroVAX 3300, 3400 XXX */
/* VAX_BTYP_655 0x0A000001 MicroVAX 3800, 3900 XXX */
#define VAX_BTYP_9CC 0x0A000002 /* VAX 6000 model 210/310 */
#define VAX_BTYP_60 0x0A000003 /* VAXstation 3520, 3540 */
#define VAX_BTYP_420 0x0A000004 /* VAXstation 3100 models 10 - 48 */
#define VAX_BTYP_IS1 0x0A000006 /* Infoserver 1000 */
#define VAX_BTYP_510 0x0A000007 /* VAXft model 110 */
/* VAX_BTYP_520 0x0A000007 VAXft model 310 */
/*
* SID Extension register definitions for CVAX series
*/
#define VAX_SIE_KA640 0x2 /* KA640 MicroVAX 3300, 3400 */
#define VAX_SIE_KA650 0x1 /* KA650 MicroVAX 3500, 3600 */
#define VAX_SIE_KA655 0x3 /* KA655 MicroVAX 3800, 3900 */
/*
* Rigel chip series (1990)
*/
#define VAX_TYP_RIGEL 11
/* VAX_TYP_9RR 11 */
#define VAX_BTYP_670 0x0B000001 /* VAX 4000 model 300 */
#define VAX_BTYP_9RR 0x0B000002 /* VAX 6000 model 410-460 */
#define VAX_BTYP_43 0x0B000004 /* VAXstation 3100 model 76 */
/*
* Aquarius series (1990)
*/
#define VAX_TYP_9000 14
#define VAX_BTYP_9AR 0x0E00000? /* VAX 9000 models 210, 410-440 */
#define VAX_BTYP_9AQ 0x0E00000? /* VAX 9000 models 400-800 */
/*
* Polarstar series (1988)
*/
#define VAX_TYP_8PS 17
#define VAX_BTYP_8PS 0x11000000 /* VAX 8810 to 8840 */
/*
* Mariah chip series (1991)
*/
#define VAX_TYP_MARIAH 18
#define VAX_TYP_V12 18
#define VAX_BTYP_690 0x12000001 /* VAX 4000 model 400 */
#define VAX_BTYP_1202 0x12000002 /* VAX 6000 model 510-560 */
#define VAX_BTYP_46 0x12000004 /* VAXstation 4000/60, 3100/80 */
/*
* NVAX chip series (1991)
*/
#define VAX_TYP_NVAX 19
#define VAX_TYP_V13 19
#define VAX_BTYP_1301 0x13000001 /* VAX 4000 model [4-6]00 */
#define VAX_STYP_675 0x00000c /* VAX 4000 model 400 */
#define VAX_STYP_680 0x000006 /* VAX 4000 model 500 */
#define VAX_STYP_681 0x00000e /* VAX 4000 model 500A */
#define VAX_STYP_690 0x000007 /* VAX 4000 model 600 */
#define VAX_STYP_691 0x00000f /* VAX 4000 model 605A */
#define VAX_STYP_692 0x000010 /* VAX 4000 model 700? */
#define VAX_BTYP_1302 0x13000002
#define VAX_BTYP_1303 0x13000003 /* Cheetah machines */
#define VAX_STYP_50 0x000008 /* KA50 or KA55 */
#define VAX_STYP_51 0x000009 /* MicroVAX 3100 model 90 / 95 */
#define VAX_STYP_52 0x00000a /* VAX 4000 model 100 */
#define VAX_STYP_53 0x00000b /* VAX 4000 model 105A */
#define VAX_BTYP_49 0x13000004 /* VaxStation 4000 model 90 */
/*
* SOC chip series (1991)
*/
#define VAX_TYP_SOC 20
#define VAX_TYP_V14 20
#define VAX_BTYP_660 0x14000001 /* VAX 4000 model 200 */
#define VAX_BTYP_48 0x14000004 /* VS4000/VLC and MV3100/{30,40} */
#define VAX_STYP_45 0x000000 /* MicroVAX 3100 {30,40} */
#define VAX_VTYP_45 0x00000001 /* MicroVAX 3100 {30,40} */
#define VAX_STYP_48 0x000001 /* VAXstation 4000 VLC */
#define VAX_VTYP_48 0x00000002 /* VAXstation 4000 VLC */
#define VAX_BTYP_550 0x14000007 /* VAXft model 410, 610 */
/*
* NVAX+ chip series (1991)
*/
#define VAX_TYP_NVPLUS 23
#define VAX_TYP_V17 23
#define VAX_BTYP_1701 0x17000001
/*
* Highest Number supported by OpenBSD/VAX
*/
#define VAX_TYP_MAX VAX_TYP_RIGEL
/*
* compatibility with old names:
*/
#define VAX_780 VAX_TYP_780
#define VAX_750 VAX_TYP_750
#define VAX_730 VAX_TYP_730
#define VAX_8600 VAX_TYP_790
#define VAX_8200 VAX_TYP_8SS
#define VAX_8800 VAX_TYP_8NN
#define VAX_610 VAX_TYP_UV1
#define VAX_78032 VAX_TYP_UV2
#define VAX_650 VAX_TYP_CVAX
/*
* Some common-used external variables.
*/
extern int vax_cputype; /* general, highest byte of the SID-register */
extern int vax_cpudata; /* general, the contents of the SID-register */
extern int vax_siedata; /* contents of the SIE register */
extern int vax_bustype; /* HW-dep., setup at consinit() in ka???.c */
extern int vax_boardtype; /* HW-dep., msb of SID | SIE (SID-extension) */
extern int vax_confdata; /* HW-dep., hardware dependent config-data */
|