1 1.21 andvar /* $NetBSD: rdreg.h,v 1.21 2024/02/10 08:24:50 andvar Exp $ */ 2 1.5 cgd 3 1.1 cgd /* 4 1.13 rmind * Copyright (c) 1988 University of Utah. 5 1.4 mycroft * Copyright (c) 1982, 1990, 1993 6 1.4 mycroft * The Regents of the University of California. All rights reserved. 7 1.10 agc * 8 1.10 agc * This code is derived from software contributed to Berkeley by 9 1.10 agc * the Systems Programming Group of the University of Utah Computer 10 1.10 agc * Science Department. 11 1.10 agc * 12 1.10 agc * Redistribution and use in source and binary forms, with or without 13 1.10 agc * modification, are permitted provided that the following conditions 14 1.10 agc * are met: 15 1.10 agc * 1. Redistributions of source code must retain the above copyright 16 1.10 agc * notice, this list of conditions and the following disclaimer. 17 1.10 agc * 2. Redistributions in binary form must reproduce the above copyright 18 1.10 agc * notice, this list of conditions and the following disclaimer in the 19 1.10 agc * documentation and/or other materials provided with the distribution. 20 1.10 agc * 3. Neither the name of the University nor the names of its contributors 21 1.10 agc * may be used to endorse or promote products derived from this software 22 1.10 agc * without specific prior written permission. 23 1.10 agc * 24 1.10 agc * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 25 1.10 agc * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 26 1.10 agc * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 27 1.10 agc * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 28 1.10 agc * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 29 1.10 agc * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 30 1.10 agc * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 31 1.10 agc * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 32 1.10 agc * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 33 1.10 agc * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 34 1.10 agc * SUCH DAMAGE. 35 1.10 agc * 36 1.10 agc * from: Utah $Hdr: rdreg.h 1.2 90/10/12$ 37 1.10 agc * 38 1.10 agc * @(#)rdreg.h 8.1 (Berkeley) 6/10/93 39 1.10 agc */ 40 1.1 cgd 41 1.1 cgd struct rd_iocmd { 42 1.20 tsutsui uint8_t c_pad; 43 1.20 tsutsui uint8_t c_unit; 44 1.20 tsutsui uint8_t c_volume; 45 1.20 tsutsui uint8_t c_saddr; 46 1.20 tsutsui uint16_t c_hiaddr; 47 1.20 tsutsui uint32_t c_addr; 48 1.20 tsutsui uint8_t c_nop2; 49 1.20 tsutsui uint8_t c_slen; 50 1.20 tsutsui uint32_t c_len; 51 1.20 tsutsui uint8_t c_cmd; 52 1.20 tsutsui uint8_t c_pad2; 53 1.8 gmcgarry } __attribute__((__packed__)); 54 1.1 cgd 55 1.1 cgd struct rd_rscmd { 56 1.20 tsutsui uint8_t c_unit; 57 1.20 tsutsui uint8_t c_sram; 58 1.20 tsutsui uint8_t c_ram; 59 1.20 tsutsui uint8_t c_cmd; 60 1.8 gmcgarry } __attribute__((__packed__)); 61 1.1 cgd 62 1.1 cgd struct rd_stat { 63 1.20 tsutsui uint8_t c_vu; 64 1.20 tsutsui uint8_t c_pend; 65 1.20 tsutsui uint16_t c_ref; 66 1.20 tsutsui uint16_t c_fef; 67 1.20 tsutsui uint16_t c_aef; 68 1.20 tsutsui uint16_t c_ief; 69 1.1 cgd union { 70 1.20 tsutsui uint8_t cu_raw[10]; 71 1.1 cgd struct { 72 1.20 tsutsui uint16_t cu_msw; 73 1.20 tsutsui uint32_t cu_lsl; 74 1.1 cgd } cu_sva; 75 1.1 cgd struct { 76 1.20 tsutsui uint32_t cu_cyhd; 77 1.20 tsutsui uint16_t cu_sect; 78 1.1 cgd } cu_tva; 79 1.1 cgd } c_pf; 80 1.8 gmcgarry } __attribute__((__packed__)); 81 1.14 tsutsui #define c_raw c_pf.cu_raw 82 1.14 tsutsui #define c_blk c_pf.cu_sva.cu_lsl /* for now */ 83 1.14 tsutsui #define c_tva c_pf.cu_tva 84 1.1 cgd 85 1.1 cgd struct rd_ssmcmd { 86 1.20 tsutsui uint8_t c_unit; 87 1.20 tsutsui uint8_t c_cmd; 88 1.20 tsutsui uint16_t c_refm; 89 1.20 tsutsui uint16_t c_fefm; 90 1.20 tsutsui uint16_t c_aefm; 91 1.20 tsutsui uint16_t c_iefm; 92 1.8 gmcgarry } __attribute__((__packed__)); 93 1.1 cgd 94 1.1 cgd struct rd_srcmd { 95 1.20 tsutsui uint8_t c_unit; 96 1.20 tsutsui uint8_t c_nop; 97 1.20 tsutsui uint8_t c_cmd; 98 1.20 tsutsui uint8_t c_param; 99 1.8 gmcgarry } __attribute__((__packed__)); 100 1.1 cgd 101 1.1 cgd struct rd_clearcmd { 102 1.20 tsutsui uint8_t c_unit; 103 1.20 tsutsui uint8_t c_cmd; 104 1.8 gmcgarry } __attribute__((__packed__)); 105 1.1 cgd 106 1.4 mycroft /* HW ids */ 107 1.17 tsutsui #define RD7946AID 0x220 /* also 7945A and 7941A */ 108 1.4 mycroft #define RD9134DID 0x221 /* also 9122S */ 109 1.4 mycroft #define RD9134LID 0x222 /* also 9122D */ 110 1.4 mycroft #define RD7912PID 0x209 111 1.14 tsutsui #define RD7914CTID 0x20A 112 1.4 mycroft #define RD7914PID 0x20B 113 1.4 mycroft #define RD7958AID 0x22B 114 1.14 tsutsui #define RD7957AID 0x22A 115 1.4 mycroft #define RD7933HID 0x212 116 1.4 mycroft #define RD7936HID 0x213 /* just guessing -- as of yet unknown */ 117 1.4 mycroft #define RD7937HID 0x214 118 1.14 tsutsui #define RD7957BID 0x22C /* another guess based on 7958B */ 119 1.14 tsutsui #define RD7958BID 0x22D 120 1.14 tsutsui #define RD7959BID 0x22E /* another guess based on 7958B */ 121 1.14 tsutsui #define RD2200AID 0x22F 122 1.14 tsutsui #define RD2203AID 0x230 /* yet another guess */ 123 1.17 tsutsui #define RD2202AID 0x231 /* from hpdrive.ini.sample */ 124 1.17 tsutsui #define RD7908AID 0x200 /* from hpdrive.ini.sample */ 125 1.17 tsutsui #define RD7911AID 0x204 /* from hpdrive.ini.sample */ 126 1.4 mycroft 127 1.16 tsutsui /* Drive names -- per identify description structure */ 128 1.16 tsutsui #define RD7945ANAME "079450" 129 1.16 tsutsui #define RD9134DNAME "091340" 130 1.16 tsutsui #define RD9122SNAME "091220" 131 1.16 tsutsui #define RD7912PNAME "079120" 132 1.16 tsutsui #define RD7914PNAME "079140" 133 1.16 tsutsui #define RD7958ANAME "079580" 134 1.16 tsutsui #define RD7957ANAME "079570" 135 1.16 tsutsui #define RD7933HNAME "079330" 136 1.16 tsutsui #define RD9134LNAME "091340" 137 1.16 tsutsui #define RD7936HNAME "079360" 138 1.16 tsutsui #define RD7937HNAME "079370" 139 1.16 tsutsui #define RD7914CTNAME "079140" 140 1.16 tsutsui #define RD9122DNAME RD9122SNAME 141 1.16 tsutsui #define RD7957BNAME "079571" 142 1.16 tsutsui #define RD7958BNAME "079581" 143 1.16 tsutsui #define RD7959BNAME "079591" 144 1.16 tsutsui #define RD2200ANAME "022000" 145 1.16 tsutsui #define RD2203ANAME "022030" 146 1.17 tsutsui #define RD2202ANAME "022020" 147 1.17 tsutsui #define RD7908ANAME "079080" 148 1.17 tsutsui #define RD7911ANAME "079110" 149 1.17 tsutsui #define RD7941ANAME "079410" 150 1.16 tsutsui 151 1.16 tsutsui #define RDNAMELEN 6 152 1.16 tsutsui 153 1.21 andvar /* SW ids -- indices into rdidentinfo, order is arbitrary */ 154 1.1 cgd #define RD7945A 0 155 1.1 cgd #define RD9134D 1 156 1.1 cgd #define RD9122S 2 157 1.1 cgd #define RD7912P 3 158 1.1 cgd #define RD7914P 4 159 1.1 cgd #define RD7958A 5 160 1.14 tsutsui #define RD7957A 6 161 1.1 cgd #define RD7933H 7 162 1.1 cgd #define RD9134L 8 163 1.1 cgd #define RD7936H 9 164 1.1 cgd #define RD7937H 10 165 1.14 tsutsui #define RD7914CT 11 166 1.14 tsutsui #define RD7946A 12 167 1.14 tsutsui #define RD9122D 13 168 1.14 tsutsui #define RD7957B 14 169 1.14 tsutsui #define RD7958B 15 170 1.14 tsutsui #define RD7959B 16 171 1.16 tsutsui #define RD2200A 17 172 1.16 tsutsui #define RD2203A 18 173 1.17 tsutsui #define RD2202A 19 174 1.17 tsutsui #define RD7908A 20 175 1.17 tsutsui #define RD7911A 21 176 1.17 tsutsui #define RD7941A 22 177 1.1 cgd 178 1.4 mycroft #define NRD7945ABPT 16 179 1.1 cgd #define NRD7945ATRK 7 180 1.19 tsutsui #define NRD7945ACYL 968 181 1.19 tsutsui #define NRD7945ABLK 108416 182 1.19 tsutsui 183 1.4 mycroft #define NRD9134DBPT 16 184 1.1 cgd #define NRD9134DTRK 6 185 1.19 tsutsui #define NRD9134DCYL 303 186 1.19 tsutsui #define NRD9134DBLK 29088 187 1.19 tsutsui 188 1.4 mycroft #define NRD9122SBPT 8 189 1.1 cgd #define NRD9122STRK 2 190 1.19 tsutsui #define NRD9122SCYL 77 191 1.19 tsutsui #define NRD9122SBLK 1232 192 1.19 tsutsui 193 1.4 mycroft #define NRD7912PBPT 32 194 1.1 cgd #define NRD7912PTRK 7 195 1.19 tsutsui #define NRD7912PCYL 572 196 1.19 tsutsui #define NRD7912PBLK 128128 197 1.19 tsutsui 198 1.4 mycroft #define NRD7914PBPT 32 199 1.1 cgd #define NRD7914PTRK 7 200 1.19 tsutsui #define NRD7914PCYL 1152 201 1.19 tsutsui #define NRD7914PBLK 258048 202 1.19 tsutsui 203 1.4 mycroft #define NRD7933HBPT 46 204 1.1 cgd #define NRD7933HTRK 13 205 1.19 tsutsui #define NRD7933HCYL 1321 206 1.19 tsutsui #define NRD7933HBLK 789958 207 1.19 tsutsui 208 1.4 mycroft #define NRD9134LBPT 16 209 1.1 cgd #define NRD9134LTRK 5 210 1.19 tsutsui #define NRD9134LCYL 973 211 1.19 tsutsui #define NRD9134LBLK 77840 212 1.19 tsutsui 213 1.17 tsutsui #define NRD7911ABPT 32 214 1.17 tsutsui #define NRD7911ATRK 3 215 1.19 tsutsui #define NRD7911ACYL 572 216 1.19 tsutsui #define NRD7911ABLK 54912 217 1.19 tsutsui 218 1.17 tsutsui #define NRD7941ABPT 16 219 1.17 tsutsui #define NRD7941ATRK 3 220 1.19 tsutsui #define NRD7941ACYL 968 221 1.19 tsutsui #define NRD7941ABLK 46464 222 1.1 cgd 223 1.1 cgd /* 224 1.1 cgd * Several HP drives have an odd number of 256 byte sectors per track. 225 1.1 cgd * This makes it rather difficult to break them into 512 and 1024 byte blocks. 226 1.1 cgd * So...we just do like HPUX and don't bother to respect hardware track/head 227 1.18 andvar * boundaries -- we just mold the disk so that we use the entire capacity. 228 1.18 andvar * HPUX also sometimes doesn't abide by cylinder boundaries, we attempt to 229 1.1 cgd * whenever possible. 230 1.1 cgd * 231 1.1 cgd * DISK REAL (256 BPS) HPUX (1024 BPS) BSD (512 BPS) 232 1.1 cgd * SPT x HD x CYL SPT x HD x CYL SPT x HD x CYL 233 1.1 cgd * ----- --------------- --------------- -------------- 234 1.17 tsutsui * 7936H: 123 x 7 x 1396 25 x 7 x 1716 123 x 7 x 698 235 1.17 tsutsui * 7937H: 123 x 13 x 1396 25 x 16 x 1395 123 x 13 x 698 236 1.1 cgd * 237 1.1 cgd * 7957A: 63 x 5 x 1013 11 x 7 x 1036 22 x 7 x 1036 238 1.1 cgd * 7958A: 63 x 8 x 1013 21 x 6 x 1013 36 x 7 x 1013 239 1.1 cgd * 240 1.1 cgd * 7957B: 63 x 4 x 1269 9 x 7 x 1269 18 x 7 x 1269 241 1.1 cgd * 7958B: 63 x 6 x 1572 21 x 9 x 786 42 x 9 x 786 242 1.1 cgd * 7959B: 63 x 12 x 1572 21 x 9 x 1572 42 x 9 x 1572 243 1.1 cgd * 244 1.1 cgd * 2200A: 113 x 8 x 1449 113 x 2 x 1449 113 x 4 x 1449 245 1.1 cgd * 2203A: 113 x 16 x 1449 113 x 4 x 1449 113 x 8 x 1449 246 1.17 tsutsui * 2202A: 113 x 16 x 1449 113 x 4 x 1449 113 x 8 x 1449 247 1.17 tsutsui * 248 1.17 tsutsui * 7908A: 35 x 5 x 370 ??? x ? x ??? 35 x 5 x 185 249 1.1 cgd */ 250 1.4 mycroft #define NRD7936HBPT 123 251 1.4 mycroft #define NRD7936HTRK 7 252 1.19 tsutsui #define NRD7936HCYL 698 253 1.19 tsutsui #define NRD7936HBLK 600978 254 1.19 tsutsui 255 1.4 mycroft #define NRD7937HBPT 123 256 1.4 mycroft #define NRD7937HTRK 13 257 1.19 tsutsui #define NRD7937HCYL 698 258 1.19 tsutsui #define NRD7937HBLK 1116102 259 1.19 tsutsui 260 1.4 mycroft #define NRD7957ABPT 22 261 1.4 mycroft #define NRD7957ATRK 7 262 1.19 tsutsui #define NRD7957ACYL 1036 263 1.19 tsutsui #define NRD7957ABLK 159544 264 1.19 tsutsui 265 1.4 mycroft #define NRD7958ABPT 36 266 1.4 mycroft #define NRD7958ATRK 7 267 1.19 tsutsui #define NRD7958ACYL 1013 268 1.19 tsutsui #define NRD7958ABLK 255276 269 1.19 tsutsui 270 1.4 mycroft #define NRD7957BBPT 18 271 1.4 mycroft #define NRD7957BTRK 7 272 1.19 tsutsui #define NRD7957BCYL 1269 273 1.19 tsutsui #define NRD7957BBLK 159894 274 1.19 tsutsui 275 1.4 mycroft #define NRD7958BBPT 42 276 1.4 mycroft #define NRD7958BTRK 9 277 1.19 tsutsui #define NRD7958BCYL 786 278 1.19 tsutsui #define NRD7958BBLK 297108 279 1.19 tsutsui 280 1.4 mycroft #define NRD7959BBPT 42 281 1.4 mycroft #define NRD7959BTRK 9 282 1.19 tsutsui #define NRD7959BCYL 1572 283 1.19 tsutsui #define NRD7959BBLK 594216 284 1.19 tsutsui 285 1.4 mycroft #define NRD2200ABPT 113 286 1.4 mycroft #define NRD2200ATRK 4 287 1.19 tsutsui #define NRD2200ACYL 1449 288 1.19 tsutsui #define NRD2200ABLK 654948 289 1.19 tsutsui 290 1.4 mycroft #define NRD2203ABPT 113 291 1.4 mycroft #define NRD2203ATRK 8 292 1.19 tsutsui #define NRD2203ACYL 1449 293 1.19 tsutsui #define NRD2203ABLK 1309896 294 1.19 tsutsui 295 1.17 tsutsui #define NRD2202ABPT 113 296 1.17 tsutsui #define NRD2202ATRK 8 297 1.19 tsutsui #define NRD2202ACYL 1449 298 1.19 tsutsui #define NRD2202ABLK 1309896 299 1.19 tsutsui 300 1.17 tsutsui #define NRD7908ABPT 35 301 1.17 tsutsui #define NRD7908ATRK 5 302 1.19 tsutsui #define NRD7908ACYL 185 303 1.19 tsutsui #define NRD7908ABLK 32375 304 1.1 cgd 305 1.1 cgd /* controller "unit" number */ 306 1.1 cgd #define RDCTLR 15 307 1.1 cgd 308 1.1 cgd /* convert 512 byte count into DEV_BSIZE count */ 309 1.14 tsutsui #define RDSZ(x) ((x) >> (DEV_BSHIFT-9)) 310 1.1 cgd 311 1.1 cgd /* convert block number into sector number and back */ 312 1.1 cgd #define RDBTOS(x) ((x) << (DEV_BSHIFT-8)) 313 1.14 tsutsui #define RDSTOB(x) ((x) >> (DEV_BSHIFT-8)) 314 1.1 cgd 315 1.1 cgd /* extract cyl/head/sect info from three-vector address */ 316 1.20 tsutsui #define RDCYL(tva) ((uint32_t)(tva).cu_cyhd >> 8) 317 1.14 tsutsui #define RDHEAD(tva) ((tva).cu_cyhd & 0xFF) 318 1.14 tsutsui #define RDSECT(tva) ((tva).cu_sect) 319 1.1 cgd 320 1.1 cgd #define REF_MASK 0x0 321 1.1 cgd #define FEF_MASK 0x0 322 1.1 cgd #define AEF_MASK 0x0 323 1.1 cgd #define IEF_MASK 0xF970 324 1.1 cgd 325 1.14 tsutsui #define FEF_CU 0x4000 /* cross-unit */ 326 1.14 tsutsui #define FEF_DR 0x0080 /* diagnostic result */ 327 1.14 tsutsui #define FEF_IMR 0x0008 /* internal maintenance release */ 328 1.1 cgd #define FEF_PF 0x0002 /* power fail */ 329 1.1 cgd #define FEF_REXMT 0x0001 /* retransmit */ 330 1.14 tsutsui #define AEF_UD 0x0040 /* unrecoverable data */ 331 1.14 tsutsui #define IEF_RRMASK 0xe000 /* request release bits */ 332 1.14 tsutsui #define IEF_MD 0x0020 /* marginal data */ 333 1.14 tsutsui #define IEF_RD 0x0010 /* recoverable data */ 334 1.1 cgd 335 1.1 cgd #define C_READ 0x00 336 1.1 cgd #define C_RAM 0x00 /* single vector (i.e. sector number) */ 337 1.1 cgd #define C_WRITE 0x02 338 1.1 cgd #define C_CLEAR 0x08 339 1.1 cgd #define C_STATUS 0x0d 340 1.1 cgd #define C_SADDR 0x10 341 1.1 cgd #define C_SLEN 0x18 342 1.1 cgd #define C_SUNIT(x) (0x20 | (x)) 343 1.14 tsutsui #define C_SVOL(x) (0x40 | (x)) 344 1.1 cgd #define C_NOP 0x34 345 1.14 tsutsui #define C_DESC 0x35 346 1.1 cgd #define C_SREL 0x3b 347 1.1 cgd #define C_SSM 0x3e 348 1.1 cgd #define C_SRAM 0x48 349 1.14 tsutsui #define C_REL 0xc0 350 1.1 cgd 351 1.1 cgd #define C_CMD 0x05 352 1.1 cgd #define C_EXEC 0x0e 353 1.1 cgd #define C_QSTAT 0x10 354 1.1 cgd #define C_TCMD 0x12 355