* Copyright (c) 1982, 1986, 1988 Regents of the University of California.
* All rights reserved. The Berkeley software License Agreement
* specifies the terms and conditions for redistribution.
* @(#)hpmaptype.c 7.8 (Berkeley) 6/14/88
* RP??/RM?? drive type mapping routine.
* Used for compatibility with unlabeled disks.
#include "../machine/pte.h"
#include "../vaxmba/hpreg.h"
#include "../vaxmba/mbareg.h"
short rp06_off
[8] = { 0, 38, 0, -1, -1, -1, 118, -1 };
short rm03_off
[8] = { 0, 100, 0, -1, -1, -1, 309, -1 };
short rm05_off
[8] = { 0, 27, 0, 562, 589, 681, 562, 82 };
short rm80_off
[8] = { 0, 37, 0, -1, -1, -1, 115, -1 };
short rp07_off
[8] = { 0, 10, 0, 235, 245, 437, 235, 52 };
short ml_off
[8] = { 0, -1, -1, -1, -1, -1, -1, -1 };
/*short cdc9775_off[8] = { 0, 13, 0, -1, -1, -1, 294, 66 };*/
short cdc9730_off
[8] = { 0, 50, 0, -1, -1, -1, 155, -1 };
short capricorn_off
[8] = { 0, 32, 0, 668, 723, 778, 668, 98 };
short eagle_off
[8] = { 0, 17, 0, 391, 408, 728, 391, 87 };
short fj2361_off
[8] = { 0, 13, 0, 294, 307, 547, 294, 66 };
short fj2361a_off
[8] = { 0, 12, 0, 277, 289, 515, 277, 62 };
* hptypes is used to translate Massbus drive type and other information
* into an index in hpst. The indices of hptypes and hpst must therefore agree.
MBDT_RM02
, /* actually something else */
32, 5, 32*5, 823, rm03_off
, /* RM03 */
32, 19, 32*19, 823, rm05_off
, /* RM05 */
22, 19, 22*19, 815, rp06_off
, /* RP06 */
31, 14, 31*14, 559, rm80_off
, /* RM80 */
22, 19, 22*19, 411, rp06_off
, /* RP05 */
50, 32, 50*32, 630, rp07_off
, /* RP07 */
1, 1, 1, 1, ml_off
, /* ML11A */
1, 1, 1, 1, ml_off
, /* ML11B */
32, 40, 32*40, 843, fj2361_off
, /* 9775 */
32, 10, 32*10, 823, cdc9730_off
, /* 9730 */
32, 16, 32*16, 1024, capricorn_off
, /* Ampex capricorn */
48, 20, 48*20, 842, eagle_off
, /* Fuji Eagle */
32, 5, 32*5, 823, rm03_off
, /* rm02 - not used */
32, 19, 32*19, 815, rm05_off
, /* Ampex 9300 */
32, 19, 32*19, 823, rm05_off
, /* CDC 9766 */
64, 20, 64*20, 842, fj2361_off
, /* Fuji 2361 */
68, 20, 68*20, 842, fj2361a_off
, /* Fuji 2361a */
#define NTYPES (sizeof(hpst) / sizeof(hpst[0]))
#define MASKREG(reg) ((reg)&0xffff)
hpmaptype(hpaddr
, type
, unit
, lp
)
register struct hpdevice
*hpaddr
;
register struct disklabel
*lp
;
for (i
= 0; hptypes
[i
]; i
++)
printf("unknown drive type\n");
* Handle SI model byte stuff when
* we think it's an RM03 or RM05.
if (type
== HPDT_RM03
|| type
== HPDT_RM05
) {
if ((hpsn
& SIMB_LU
) == unit
)
switch ((hpsn
& SIMB_MB
) &~ (SIMB_S6
|SIRM03
|SIRM05
)) {
* RM02: EMULEX controller. Map to correct
* drive type by checking the holding
* register for the disk geometry.
int nsectors
, ntracks
, ncyl
;
hpaddr
->hphr
= HPHR_MAXTRAK
;
ntracks
= MASKREG(hpaddr
->hphr
) + 1;
hpaddr
->hphr
= HPHR_MAXSECT
;
nsectors
= MASKREG(hpaddr
->hphr
) + 1;
hpaddr
->hphr
= HPHR_MAXCYL
;
ncyl
= MASKREG(hpaddr
->hphr
) + 1;
for (type
= 0; type
< NTYPES
; type
++)
if (hpst
[type
].nsect
== nsectors
&&
hpst
[type
].ntrak
== ntracks
&&
printf("%d sectors, %d tracks, %d cyl?\n",
nsectors
, ntracks
, ncyl
);
hpaddr
->hpcs1
= HP_DCLR
|HP_GO
;
* set up minimal disk label.
lp
->d_nsectors
= st
->nsect
;
lp
->d_ntracks
= st
->ntrak
;
lp
->d_secpercyl
= st
->nspc
;
lp
->d_ncylinders
= st
->ncyl
;
lp
->d_secperunit
= st
->nspc
* st
->ncyl
;
for (i
= 0; i
< 8; i
++) {
lp
->d_partitions
[i
].p_size
= 0;
lp
->d_partitions
[i
].p_offset
= st
->off
[i
] *
lp
->d_partitions
[i
].p_size
= lp
->d_secperunit
;