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
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
|
/* $NetBSD: rdreg.h,v 1.7 1996/02/09 18:00:37 scottr Exp $ */
/*
* Copyright (c) 1988 University of Utah.
* Copyright (c) 1982, 1990, 1993
* The Regents of the University of California. All rights reserved.
*
* This code is derived from software contributed to Berkeley by
* the Systems Programming Group of the University of Utah Computer
* Science Department.
*
* 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 by the University of
* California, Berkeley and its contributors.
* 4. Neither the name of the University 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 REGENTS 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 REGENTS 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.
*
* from: Utah $Hdr: rdreg.h 1.2 90/10/12$
*
* @(#)rdreg.h 8.1 (Berkeley) 6/10/93
*/
struct rd_iocmd {
char c_pad;
char c_unit;
char c_volume;
char c_saddr;
short c_hiaddr;
long c_addr;
char c_nop2;
char c_slen;
long c_len;
char c_cmd;
char c_pad2;
};
struct rd_rscmd {
char c_unit;
char c_sram;
char c_ram;
char c_cmd;
};
struct rd_stat {
char c_vu;
char c_pend;
short c_ref;
short c_fef;
short c_aef;
short c_ief;
union {
char cu_raw[10];
struct {
short cu_msw;
long cu_lsl;
} cu_sva;
struct {
long cu_cyhd;
short cu_sect;
} cu_tva;
} c_pf;
};
#define c_raw c_pf.cu_raw
#define c_blk c_pf.cu_sva.cu_lsl /* for now */
#define c_tva c_pf.cu_tva
struct rd_ssmcmd {
char c_unit;
char c_cmd;
short c_refm;
short c_fefm;
short c_aefm;
short c_iefm;
};
struct rd_srcmd {
char c_unit;
char c_nop;
char c_cmd;
char c_param;
};
struct rd_clearcmd {
char c_unit;
char c_cmd;
};
struct rd_describe {
u_int d_iuw:16, /* controller: installed unit word */
d_cmaxxfr:16, /* controller: max transfer rate (Kb) */
d_ctype:8, /* controller: controller type */
d_utype:8, /* unit: unit type */
d_name:24, /* unit: name (6 BCD digits) */
d_sectsize:16, /* unit: # of bytes per block (sector) */
d_blkbuf:8, /* unit: # of blocks which can be buffered */
d_burstsize:8, /* unit: recommended burst size */
d_blocktime:16, /* unit: block time (u-sec) */
d_uavexfr:16, /* unit: average transfer rate (Kb) */
d_retry:16, /* unit: optimal retry time (1/100-sec) */
d_access:16, /* unit: access time param (1/100-sec) */
d_maxint:8, /* unit: maximum interleave */
d_fvbyte:8, /* unit: fixed volume byte */
d_rvbyte:8, /* unit: removeable volume byte */
d_maxcyl:24, /* volume: maximum cylinder */
d_maxhead:8, /* volume: maximum head */
d_maxsect:16, /* volume: maximum sector on track */
d_maxvsecth:16, /* volume: maximum sector on volume (MSW) */
d_maxvsectl:32, /* volume: maximum sector on volume (LSWs) */
d_interleave:8; /* volume: current interleave */
};
/* HW ids */
#define RD7946AID 0x220 /* also 7945A */
#define RD9134DID 0x221 /* also 9122S */
#define RD9134LID 0x222 /* also 9122D */
#define RD7912PID 0x209
#define RD7914CTID 0x20A
#define RD7914PID 0x20B
#define RD7958AID 0x22B
#define RD7957AID 0x22A
#define RD7933HID 0x212
#define RD7936HID 0x213 /* just guessing -- as of yet unknown */
#define RD7937HID 0x214
#define RD7957BID 0x22C /* another guess based on 7958B */
#define RD7958BID 0x22D
#define RD7959BID 0x22E /* another guess based on 7958B */
#define RD2200AID 0x22F
#define RD2203AID 0x230 /* yet another guess */
/* SW ids -- indicies into rdidentinfo, order is arbitrary */
#define RD7945A 0
#define RD9134D 1
#define RD9122S 2
#define RD7912P 3
#define RD7914P 4
#define RD7958A 5
#define RD7957A 6
#define RD7933H 7
#define RD9134L 8
#define RD7936H 9
#define RD7937H 10
#define RD7914CT 11
#define RD7946A 12
#define RD9122D 13
#define RD7957B 14
#define RD7958B 15
#define RD7959B 16
#define NRD7945ABPT 16
#define NRD7945ATRK 7
#define NRD9134DBPT 16
#define NRD9134DTRK 6
#define NRD9122SBPT 8
#define NRD9122STRK 2
#define NRD7912PBPT 32
#define NRD7912PTRK 7
#define NRD7914PBPT 32
#define NRD7914PTRK 7
#define NRD7933HBPT 46
#define NRD7933HTRK 13
#define NRD9134LBPT 16
#define NRD9134LTRK 5
/*
* Several HP drives have an odd number of 256 byte sectors per track.
* This makes it rather difficult to break them into 512 and 1024 byte blocks.
* So...we just do like HPUX and don't bother to respect hardware track/head
* boundries -- we just mold the disk so that we use the entire capacity.
* HPUX also sometimes doen't abide by cylinder boundries, we attempt to
* whenever possible.
*
* DISK REAL (256 BPS) HPUX (1024 BPS) BSD (512 BPS)
* SPT x HD x CYL SPT x HD x CYL SPT x HD x CYL
* ----- --------------- --------------- --------------
* 7936: 123 x 7 x 1396 25 x 7 x 1716 123 x 7 x 698
* 7937: 123 x 13 x 1396 25 x 16 x 1395 123 x 13 x 698
*
* 7957A: 63 x 5 x 1013 11 x 7 x 1036 22 x 7 x 1036
* 7958A: 63 x 8 x 1013 21 x 6 x 1013 36 x 7 x 1013
*
* 7957B: 63 x 4 x 1269 9 x 7 x 1269 18 x 7 x 1269
* 7958B: 63 x 6 x 1572 21 x 9 x 786 42 x 9 x 786
* 7959B: 63 x 12 x 1572 21 x 9 x 1572 42 x 9 x 1572
*
* 2200A: 113 x 8 x 1449 113 x 2 x 1449 113 x 4 x 1449
* 2203A: 113 x 16 x 1449 113 x 4 x 1449 113 x 8 x 1449
*/
#define NRD7936HBPT 123
#define NRD7936HTRK 7
#define NRD7937HBPT 123
#define NRD7937HTRK 13
#define NRD7957ABPT 22
#define NRD7957ATRK 7
#define NRD7958ABPT 36
#define NRD7958ATRK 7
#define NRD7957BBPT 18
#define NRD7957BTRK 7
#define NRD7958BBPT 42
#define NRD7958BTRK 9
#define NRD7959BBPT 42
#define NRD7959BTRK 9
#define NRD2200ABPT 113
#define NRD2200ATRK 4
#define NRD2203ABPT 113
#define NRD2203ATRK 8
/* controller "unit" number */
#define RDCTLR 15
/* convert 512 byte count into DEV_BSIZE count */
#define RDSZ(x) ((x) >> (DEV_BSHIFT-9))
/* convert block number into sector number and back */
#define RDBTOS(x) ((x) << (DEV_BSHIFT-8))
#define RDSTOB(x) ((x) >> (DEV_BSHIFT-8))
/* extract cyl/head/sect info from three-vector address */
#define RDCYL(tva) ((u_long)(tva).cu_cyhd >> 8)
#define RDHEAD(tva) ((tva).cu_cyhd & 0xFF)
#define RDSECT(tva) ((tva).cu_sect)
#define REF_MASK 0x0
#define FEF_MASK 0x0
#define AEF_MASK 0x0
#define IEF_MASK 0xF970
#define FEF_CU 0x4000 /* cross-unit */
#define FEF_DR 0x0080 /* diagnostic result */
#define FEF_IMR 0x0008 /* internal maintenance release */
#define FEF_PF 0x0002 /* power fail */
#define FEF_REXMT 0x0001 /* retransmit */
#define AEF_UD 0x0040 /* unrecoverable data */
#define IEF_RRMASK 0xe000 /* request release bits */
#define IEF_MD 0x0020 /* marginal data */
#define IEF_RD 0x0010 /* recoverable data */
#define C_READ 0x00
#define C_RAM 0x00 /* single vector (i.e. sector number) */
#define C_WRITE 0x02
#define C_CLEAR 0x08
#define C_STATUS 0x0d
#define C_SADDR 0x10
#define C_SLEN 0x18
#define C_SUNIT(x) (0x20 | (x))
#define C_SVOL(x) (0x40 | (x))
#define C_NOP 0x34
#define C_DESC 0x35
#define C_SREL 0x3b
#define C_SSM 0x3e
#define C_SRAM 0x48
#define C_REL 0xc0
#define C_CMD 0x05
#define C_EXEC 0x0e
#define C_QSTAT 0x10
#define C_TCMD 0x12
|