handle var len names, sync with vax
[unix-history] / usr / src / sys / vax / stand / hpmaptype.c
CommitLineData
8ae0e4b4 1/*
f2f9e58f 2 * Copyright (c) 1982, 1986, 1988 Regents of the University of California.
8ae0e4b4
KM
3 * All rights reserved. The Berkeley software License Agreement
4 * specifies the terms and conditions for redistribution.
5 *
4f1f6815 6 * @(#)hpmaptype.c 7.8 (Berkeley) %G%
8ae0e4b4 7 */
c29bef6b
SL
8
9/*
10 * RP??/RM?? drive type mapping routine.
80c81fbf 11 * Used for compatibility with unlabeled disks.
c29bef6b 12 */
80c81fbf 13#ifdef COMPAT_42
c29bef6b
SL
14#include "../machine/pte.h"
15
39c71180
MK
16#include "param.h"
17#include "inode.h"
18#include "fs.h"
19#include "disklabel.h"
c29bef6b
SL
20
21#include "../vaxmba/hpreg.h"
22#include "../vaxmba/mbareg.h"
23
24#include "saio.h"
c29bef6b 25
f7ca52be
SL
26short rp06_off[8] = { 0, 38, 0, -1, -1, -1, 118, -1 };
27short rm03_off[8] = { 0, 100, 0, -1, -1, -1, 309, -1 };
28short rm05_off[8] = { 0, 27, 0, 562, 589, 681, 562, 82 };
29short rm80_off[8] = { 0, 37, 0, -1, -1, -1, 115, -1 };
4f1f6815 30short rp07_off[8] = { 0, 10, 0, 235, 245, 437, 235, 52 };
c29bef6b 31short ml_off[8] = { 0, -1, -1, -1, -1, -1, -1, -1 };
80c81fbf 32/*short cdc9775_off[8] = { 0, 13, 0, -1, -1, -1, 294, 66 };*/
f7ca52be
SL
33short cdc9730_off[8] = { 0, 50, 0, -1, -1, -1, 155, -1 };
34short capricorn_off[8] = { 0, 32, 0, 668, 723, 778, 668, 98 };
4f1f6815 35short eagle_off[8] = { 0, 17, 0, 391, 408, 728, 391, 87 };
b4cc6bf5 36short fj2361_off[8] = { 0, 13, 0, 294, 307, 547, 294, 66 };
4f1f6815 37short fj2361a_off[8] = { 0, 12, 0, 277, 289, 515, 277, 62 };
c29bef6b 38
f834e141
MK
39/*
40 * hptypes is used to translate Massbus drive type and other information
41 * into an index in hpst. The indices of hptypes and hpst must therefore agree.
42 */
43short hptypes[] = {
44 MBDT_RM03,
45 MBDT_RM05,
46 MBDT_RP06,
47 MBDT_RM80,
48 MBDT_RP05,
49 MBDT_RP07,
50 MBDT_ML11A,
51 MBDT_ML11B,
52 -1, /* 9755 */
53 -1, /* 9730 */
54 -1, /* Capricorn */
55 -1, /* Eagle */
56 MBDT_RM02, /* actually something else */
57 -1, /* 9300 */
58 -1, /* 9766 */
b4cc6bf5 59 -1, /* 2361 */
4f1f6815 60 -1, /* 2361A */
f834e141
MK
61 0
62};
63
c29bef6b 64struct st hpst[] = {
ad8fa496 65#define HPDT_RM03 0
f7ca52be 66 32, 5, 32*5, 823, rm03_off, /* RM03 */
ad8fa496 67#define HPDT_RM05 1
f7ca52be 68 32, 19, 32*19, 823, rm05_off, /* RM05 */
ad8fa496 69#define HPDT_RP06 2
f7ca52be 70 22, 19, 22*19, 815, rp06_off, /* RP06 */
ad8fa496 71#define HPDT_RM80 3
c29bef6b 72 31, 14, 31*14, 559, rm80_off, /* RM80 */
ad8fa496
SL
73#define HPDT_RP05 4
74 22, 19, 22*19, 411, rp06_off, /* RP05 */
75#define HPDT_RP07 5
f7ca52be 76 50, 32, 50*32, 630, rp07_off, /* RP07 */
ad8fa496 77#define HPDT_ML11A 6
c29bef6b 78 1, 1, 1, 1, ml_off, /* ML11A */
ad8fa496 79#define HPDT_ML11B 7
c29bef6b 80 1, 1, 1, 1, ml_off, /* ML11B */
ad8fa496 81#define HPDT_9775 8
80c81fbf 82 32, 40, 32*40, 843, fj2361_off, /* 9775 */
ad8fa496 83#define HPDT_9730 9
f7ca52be 84 32, 10, 32*10, 823, cdc9730_off, /* 9730 */
ad8fa496 85#define HPDT_CAP 10
f7ca52be 86 32, 16, 32*16, 1024, capricorn_off, /* Ampex capricorn */
ad8fa496 87#define HPDT_EAGLE 11
e4b4ea82 88 48, 20, 48*20, 842, eagle_off, /* Fuji Eagle */
ad8fa496 89#define HPDT_RM02 12
f834e141 90 32, 5, 32*5, 823, rm03_off, /* rm02 - not used */
ad8fa496 91#define HPDT_9300 13
f7ca52be 92 32, 19, 32*19, 815, rm05_off, /* Ampex 9300 */
f834e141
MK
93#define HPDT_9766 14
94 32, 19, 32*19, 823, rm05_off, /* CDC 9766 */
b4cc6bf5
MK
95#define HPDT_2361 15
96 64, 20, 64*20, 842, fj2361_off, /* Fuji 2361 */
4f1f6815
KB
97#define HPDT_2361A
98 68, 20, 68*20, 842, fj2361a_off, /* Fuji 2361a */
c29bef6b 99};
f834e141 100#define NTYPES (sizeof(hpst) / sizeof(hpst[0]))
c29bef6b
SL
101
102#define MASKREG(reg) ((reg)&0xffff)
103
80c81fbf 104hpmaptype(hpaddr, type, unit, lp)
c29bef6b 105 register struct hpdevice *hpaddr;
80c81fbf 106 register unsigned type;
c29bef6b 107 int unit;
80c81fbf 108 register struct disklabel *lp;
c29bef6b 109{
80c81fbf
MK
110 register i;
111 register struct st *st;
f834e141 112 int hpsn;
c29bef6b 113
80c81fbf
MK
114 for (i = 0; hptypes[i]; i++)
115 if (hptypes[i] == type)
116 goto found;
f2f9e58f
MK
117 printf("unknown drive type\n");
118 return (0);
80c81fbf
MK
119
120found:
121 type = i;
c29bef6b
SL
122 /*
123 * Handle SI model byte stuff when
124 * we think it's an RM03 or RM05.
125 */
ad8fa496 126 if (type == HPDT_RM03 || type == HPDT_RM05) {
c29bef6b 127 hpsn = hpaddr->hpsn;
80c81fbf 128 if ((hpsn & SIMB_LU) == unit)
c29bef6b
SL
129 switch ((hpsn & SIMB_MB) &~ (SIMB_S6|SIRM03|SIRM05)) {
130
131 case SI9775D:
80c81fbf
MK
132 type = HPDT_9775;
133 break;
c29bef6b
SL
134
135 case SI9730D:
80c81fbf
MK
136 type = HPDT_9730;
137 break;
c29bef6b 138
c29bef6b 139 case SI9766:
80c81fbf
MK
140 type = HPDT_9766;
141 break;
c29bef6b
SL
142
143 case SI9762:
80c81fbf
MK
144 type = HPDT_RM03;
145 break;
c29bef6b
SL
146
147 case SICAPD:
80c81fbf
MK
148 type = HPDT_CAP;
149 break;
c29bef6b
SL
150
151 case SI9751D:
80c81fbf
MK
152 type = HPDT_EAGLE;
153 break;
c29bef6b 154 }
c29bef6b
SL
155 }
156 /*
f834e141 157 * RM02: EMULEX controller. Map to correct
c29bef6b
SL
158 * drive type by checking the holding
159 * register for the disk geometry.
160 */
ad8fa496 161 if (type == HPDT_RM02) {
80c81fbf 162 int nsectors, ntracks, ncyl;
35d06460 163
c29bef6b
SL
164 hpaddr->hpcs1 = HP_NOP;
165 hpaddr->hphr = HPHR_MAXTRAK;
166 ntracks = MASKREG(hpaddr->hphr) + 1;
f834e141 167 DELAY(100);
35d06460 168 hpaddr->hpcs1 = HP_NOP;
c29bef6b 169 hpaddr->hphr = HPHR_MAXSECT;
f834e141
MK
170 nsectors = MASKREG(hpaddr->hphr) + 1;
171 DELAY(100);
172 hpaddr->hpcs1 = HP_NOP;
173 hpaddr->hphr = HPHR_MAXCYL;
174 ncyl = MASKREG(hpaddr->hphr) + 1;
80c81fbf
MK
175 for (type = 0; type < NTYPES; type++)
176 if (hpst[type].nsect == nsectors &&
177 hpst[type].ntrak == ntracks &&
178 hpst[type].ncyl == ncyl)
39c71180 179 goto done;
f834e141 180
39c71180
MK
181 printf("%d sectors, %d tracks, %d cyl?\n",
182 nsectors, ntracks, ncyl);
183 type = HPDT_RM02;
35d06460
SL
184 done:
185 hpaddr->hpcs1 = HP_DCLR|HP_GO;
c29bef6b 186 }
39c71180 187
c29bef6b 188 /*
80c81fbf 189 * set up minimal disk label.
c29bef6b 190 */
80c81fbf
MK
191 st = &hpst[type];
192 lp->d_nsectors = st->nsect;
193 lp->d_ntracks = st->ntrak;
194 lp->d_secpercyl = st->nspc;
195 lp->d_ncylinders = st->ncyl;
196 lp->d_secperunit = st->nspc * st->ncyl;
197 lp->d_npartitions = 8;
198 for (i = 0; i < 8; i++) {
199 if (st->off[i] == -1)
200 lp->d_partitions[i].p_size = 0;
201 else {
202 lp->d_partitions[i].p_offset = st->off[i] *
203 lp->d_secpercyl;
204 lp->d_partitions[i].p_size = lp->d_secperunit;
205 }
206 }
f2f9e58f 207 return (1);
c29bef6b 208}
80c81fbf 209#endif COMPAT_42