|
|
1.1 ! root 1: /* ! 2: * Copyright (c) 1982, 1986 Regents of the University of California. ! 3: * All rights reserved. The Berkeley software License Agreement ! 4: * specifies the terms and conditions for redistribution. ! 5: * ! 6: * @(#)upmaptype.c 7.5 (Berkeley) 4/4/90 ! 7: */ ! 8: ! 9: /* ! 10: * UNIBUS peripheral standalone ! 11: * driver: drive type mapping routine. ! 12: */ ! 13: #ifdef COMPAT_42 ! 14: #include "param.h" ! 15: #include "dkbad.h" ! 16: #include "disklabel.h" ! 17: #include "vmmac.h" ! 18: ! 19: #include "../vax/pte.h" ! 20: #include "../vaxuba/upreg.h" ! 21: #include "../vaxuba/ubareg.h" ! 22: ! 23: #include "saio.h" ! 24: #include "savax.h" ! 25: ! 26: static short up9300_off[] = { 0, 27, 0, -1, -1, -1, 562, 82 }; ! 27: static short fj_off[] = { 0, 50, 0, -1, -1, -1, 155, -1 }; ! 28: static short upam_off[] = { 0, 32, 0, 668, 723, 778, 668, 98 }; ! 29: static short up980_off[] = { 0, 100, 0, -1, -1, -1, 309, -1 }; ! 30: static short eagle_off[] = { 0, 17, 0, 391, 408, 728, 391, 87 }; ! 31: ! 32: struct st upst[] = { ! 33: 32, 19, 32*19, 815, up9300_off, /* 9300 */ ! 34: 32, 19, 32*19, 823, up9300_off, /* 9766 */ ! 35: 32, 10, 32*10, 823, fj_off, /* Fuji 160 */ ! 36: 32, 16, 32*16, 1024, upam_off, /* Capricorn */ ! 37: 32, 5, 32*5, 823, up980_off, /* DM980 */ ! 38: 48, 20, 48*20, 842, eagle_off, /* Fuji Eagle */ ! 39: 0, 0, 0, 0, 0, ! 40: }; ! 41: ! 42: upmaptype(unit, upaddr, lp) ! 43: int unit; ! 44: register struct updevice *upaddr; ! 45: register struct disklabel *lp; ! 46: { ! 47: register struct st *st; ! 48: register int i; ! 49: int type = -1; ! 50: ! 51: upaddr->upcs1 = 0; ! 52: upaddr->upcs2 = unit % 8; ! 53: upaddr->uphr = UPHR_MAXTRAK; ! 54: for (st = upst;; ++st) { ! 55: if (!st->ntrak) ! 56: return(0); ! 57: if (upaddr->uphr == st->ntrak - 1) { ! 58: type = st - upst; ! 59: break; ! 60: } ! 61: } ! 62: if (type == 0) { ! 63: upaddr->uphr = UPHR_MAXCYL; ! 64: if (upaddr->uphr == 822) /* CDC 9766 */ ! 65: ++type; ! 66: } ! 67: upaddr->upcs2 = UPCS2_CLR; ! 68: st = &upst[type]; ! 69: ! 70: /* set up a minimal disk label */ ! 71: lp->d_nsectors = st->nsect; ! 72: lp->d_ntracks = st->ntrak; ! 73: lp->d_secpercyl = st->nspc; ! 74: lp->d_ncylinders = st->ncyl; ! 75: lp->d_secperunit = st->nspc * st->ncyl; ! 76: lp->d_npartitions = 8; ! 77: for (i = 0; i < 8; i++) ! 78: if (st->off[i] == -1) ! 79: lp->d_partitions[i].p_size = 0; ! 80: else { ! 81: lp->d_partitions[i].p_offset = st->off[i] * ! 82: lp->d_secpercyl; ! 83: lp->d_partitions[i].p_size = lp->d_secperunit; ! 84: } ! 85: return(1); ! 86: } ! 87: #endif /* COMPAT_42 */
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.