Annotation of 43BSDReno/sys/vaxbi/kdb.c, revision 1.1.1.1

1.1       root        1: /*
                      2:  * Copyright (c) 1988 Regents of the University of California.
                      3:  * All rights reserved.
                      4:  *
                      5:  * This code is derived from software contributed to Berkeley by
                      6:  * Chris Torek.
                      7:  *
                      8:  * Redistribution is only permitted until one year after the first shipment
                      9:  * of 4.4BSD by the Regents.  Otherwise, redistribution and use in source and
                     10:  * binary forms are permitted provided that: (1) source distributions retain
                     11:  * this entire copyright notice and comment, and (2) distributions including
                     12:  * binaries display the following acknowledgement:  This product includes
                     13:  * software developed by the University of California, Berkeley and its
                     14:  * contributors'' in the documentation or other materials provided with the
                     15:  * distribution and in all advertising materials mentioning features or use
                     16:  * of this software.  Neither the name of the University nor the names of
                     17:  * its contributors may be used to endorse or promote products derived from
                     18:  * this software without specific prior written permission.
                     19:  * THIS SOFTWARE IS PROVIDED AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
                     20:  * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
                     21:  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
                     22:  *
                     23:  *     @(#)kdb.c       7.9 (Berkeley) 6/28/90
                     24:  */
                     25: 
                     26: /*
                     27:  * KDB50/MSCP device driver
                     28:  */
                     29: 
                     30: /*
                     31:  * TODO
                     32:  *     rethink BI software interface
                     33:  *     write bad block forwarding code
                     34:  */
                     35: 
                     36: #include "kra.h"               /* XXX */
                     37: 
                     38: #define        DRIVENAMES      "kra"   /* XXX */
                     39: 
                     40: #if NKDB > 0
                     41: 
                     42: /*
                     43:  * CONFIGURATION OPTIONS.  The next three defines are tunable -- tune away!
                     44:  *
                     45:  * NRSPL2 and NCMDL2 control the number of response and command
                     46:  * packets respectively.  They may be any value from 0 to 7, though
                     47:  * setting them higher than 5 is unlikely to be of any value.
                     48:  * If you get warnings about your command ring being too small,
                     49:  * try increasing the values by one.
                     50:  *
                     51:  * MAXUNIT controls the maximum slave number (and hence number of drives
                     52:  * per controller) we are prepared to handle.
                     53:  */
                     54: #define        NRSPL2  5               /* log2 number of response packets */
                     55: #define NCMDL2 5               /* log2 number of command packets */
                     56: #define        MAXUNIT 8               /* maximum allowed unit number */
                     57: 
                     58: #include "param.h"
                     59: #include "systm.h"
                     60: #include "malloc.h"
                     61: #include "map.h"
                     62: #include "buf.h"
                     63: #include "conf.h"
                     64: #include "user.h"
                     65: #include "proc.h"
                     66: #include "vm.h"
                     67: #include "dkstat.h"
                     68: #include "cmap.h"
                     69: #include "syslog.h"
                     70: #include "kernel.h"
                     71: 
                     72: #define        NRSP    (1 << NRSPL2)
                     73: #define        NCMD    (1 << NCMDL2)
                     74: 
                     75: #include "../vax/pte.h"
                     76: #include "../vax/cpu.h"
                     77: #include "../vax/mscp.h"
                     78: #include "../vax/mscpvar.h"
                     79: #include "../vax/mtpr.h"
                     80: 
                     81: #include "bireg.h"
                     82: #include "kdbreg.h"
                     83: 
                     84: #include "../vaxuba/ubavar.h"
                     85: 
                     86: /*
                     87:  * Conversions from kernel virtual to physical and page table addresses.
                     88:  * PHYS works only for kernel text and primary (compile time) data addresses.
                     89:  */
                     90: #define        PHYS(cast, addr) \
                     91:        ((cast) ((int)(addr) & 0x7fffffff))
                     92: 
                     93: /*
                     94:  * KDB variables, per controller.
                     95:  */
                     96: struct kdbinfo {
                     97:        /* software info, per KDB */
                     98:        struct  kdb_regs *ki_kdb;       /* KDB registers */
                     99:        struct  kdb_regs *ki_physkdb;   /* phys address of KDB registers */
                    100:        short   ki_state;               /* KDB50 state; see below */
                    101:        short   ki_flags;               /* flags; see below */
                    102:        int     ki_micro;               /* microcode revision */
                    103:        short   ki_vec;                 /* scb vector offset */
                    104:        short   ki_wticks;              /* watchdog timer ticks */
                    105: 
                    106:        /*
                    107:         * KDB PTEs must be contiguous.  Some I/O is done on addresses
                    108:         * for which this is true (PTEs in Sysmap and Usrptmap), but
                    109:         * other transfers may have PTEs that are scattered in physical
                    110:         * space.  Ki_map maps a physically contiguous PTE space used
                    111:         * for these transfers.
                    112:         */
                    113: #define KI_MAPSIZ      (NCMD + 2)
                    114:        struct  map *ki_map;            /* resource map */
                    115: #define KI_PTES                256
                    116:        struct  pte ki_pte[KI_PTES];    /* contiguous PTE space */
                    117:        long    ki_ptephys;             /* phys address of &ki_pte[0] */
                    118: 
                    119:        struct  mscp_info ki_mi;        /* MSCP info (per mscpvar.h) */
                    120:        struct  buf ki_tab;             /* controller queue */
                    121: 
                    122:        /* stuff read and written by hardware */
                    123:        struct  kdbca ki_ca;            /* communications area */
                    124:        struct  mscp ki_rsp[NRSP];      /* response packets */
                    125:        struct  mscp ki_cmd[NCMD];      /* command packets */
                    126: } kdbinfo[NKDB];
                    127: 
                    128: #define        ki_ctlr ki_mi.mi_ctlr
                    129: 
                    130: /*
                    131:  * Controller states
                    132:  */
                    133: #define        ST_IDLE         0       /* uninitialised */
                    134: #define        ST_STEP1        1       /* in `STEP 1' */
                    135: #define        ST_STEP2        2       /* in `STEP 2' */
                    136: #define        ST_STEP3        3       /* in `STEP 3' */
                    137: #define        ST_SETCHAR      4       /* in `Set Controller Characteristics' */
                    138: #define        ST_RUN          5       /* up and running */
                    139: 
                    140: /*
                    141:  * Flags
                    142:  */
                    143: #define        KDB_ALIVE       0x01    /* this KDB50 exists */
                    144: #define        KDB_GRIPED      0x04    /* griped about cmd ring too small */
                    145: #define        KDB_INSLAVE     0x08    /* inside kdbslave() */
                    146: #define        KDB_DOWAKE      0x10    /* wakeup when ctlr init done */
                    147: 
                    148: struct kdbstats kdbstats;      /* statistics */
                    149: 
                    150: /*
                    151:  * Device to unit number and partition:
                    152:  */
                    153: #define        UNITSHIFT       3
                    154: #define        UNITMASK        7
                    155: #define        kdbunit(dev)    (minor(dev) >> UNITSHIFT)
                    156: #define        kdbpart(dev)    (minor(dev) & UNITMASK)
                    157: 
                    158: /* THIS SHOULD BE READ OFF THE PACK, PER DRIVE */
                    159: /* THESE SHOULD BE SHARED WITH uda.c (but not yet) */
                    160: struct size {
                    161:        daddr_t nblocks;
                    162:        daddr_t blkoff;
                    163: } kra81_sizes[8] = {
                    164: #ifdef MARYLAND
                    165:        67832,  0,              /* A=cyl    0 thru   94 + 2 sectors */
                    166:        67828,  67832,          /* B=cyl   95 thru  189 - 2 sectors */
                    167:        -1,     0,              /* C=cyl    0 thru 1247 */
                    168:        -1,     135660,         /* D=cyl  190 thru 1247 */
                    169:        449466, 49324,          /* E xxx */
                    170:        64260,  498790,         /* F xxx */
                    171:        328022, 563050,         /* G xxx */
                    172:        0,      0,
                    173: #else
                    174:        15884,  0,              /* a */
                    175:        33440,  15884,          /* b */
                    176:        -1,     0,              /* c */
                    177:        -1,     49324,          /* d */
                    178:        449466, 49324,          /* e */
                    179:        64260,  498790,         /* f */
                    180:        328022, 563050,         /* g */
                    181:        0,      0,
                    182: #endif
                    183: }, kra80_sizes[8] = {
                    184:        15884,  0,              /* A=blk 0 thru 15883 */
                    185:        33440,  15884,          /* B=blk 15884 thru 49323 */
                    186:        -1,     0,              /* C=blk 0 thru end */
                    187:        0,      0,
                    188:        0,      0,
                    189:        0,      0,
                    190:        82080,  49324,          /* G=blk 49324 thru 131403 */
                    191:        -1,     131404,         /* H=blk 131404 thru end */
                    192: }, kra60_sizes[8] = {
                    193:        15884,  0,              /* A=blk 0 thru 15883 */
                    194:        33440,  15884,          /* B=blk 15884 thru 49323 */
                    195:        -1,     0,              /* C=blk 0 thru end */
                    196:        -1,     49324,          /* D=blk 49324 thru end */
                    197:        0,      0,
                    198:        0,      0,
                    199:        82080,  49324,          /* G=blk 49324 thru 131403 */
                    200:        -1,     131404,         /* H=blk 131404 thru end */
                    201: };
                    202: /* END OF STUFF WHICH SHOULD BE READ IN PER DISK */
                    203: 
                    204: /*
                    205:  * Drive type index decoding table.  `ut_name' is null iff the
                    206:  * type is not known.
                    207:  */
                    208: struct kdbtypes {
                    209:        char    *ut_name;       /* drive type name */
                    210:        struct  size *ut_sizes; /* partition tables */
                    211: } kdbtypes[] = {
                    212:        NULL,           NULL,
                    213:        "ra80",         kra80_sizes,    /* 1 = ra80 */
                    214:        NULL,           NULL,
                    215:        NULL,           NULL,
                    216:        "ra60",         kra60_sizes,    /* 4 = ra60 */
                    217:        "ra81",         kra81_sizes,    /* 5 = ra81 */
                    218: };
                    219: 
                    220: #define NTYPES 6
                    221: 
                    222: /*
                    223:  * Definition of the driver for autoconf and generic MSCP code.
                    224:  * SOME OF THIS IS BOGUS (must fix config)
                    225:  */
                    226: 
                    227: #ifdef notdef          /* not when driver is for kra disks */
                    228: /*
                    229:  * Some of these variables (per-drive stuff) are shared
                    230:  * with the UDA50 code (why not, they are the same drives).
                    231:  * N.B.: kdbdinfo must not be shared.
                    232:  */
                    233: #define        kdbutab         udautab         /* shared */
                    234: #define        kdbslavereply   udaslavereply   /* shared */
                    235: #endif
                    236: 
                    237: int    kdbprobe();             /* XXX */
                    238: int    kdbslave(), kdbattach();
                    239: 
                    240: int    kdbdgram(), kdbctlrdone(), kdbunconf(), kdbiodone();
                    241: int    kdbonline(), kdbgotstatus(), kdbioerror();
                    242: 
                    243: struct uba_device *kdbdinfo[NKRA];     /* uba_device indeed! */
                    244: struct buf kdbutab[NKRA];      /* per drive transfer queue */
                    245: 
                    246: u_short kdbstd[] = { 0 };      /* XXX */
                    247: struct uba_driver kdbdriver =  /* XXX */
                    248:  { kdbprobe, kdbslave, kdbattach, 0, kdbstd, DRIVENAMES, kdbdinfo, "kdb" };
                    249: 
                    250: struct mscp_driver kdbmscpdriver =
                    251:  { MAXUNIT, NKRA, UNITSHIFT, kdbutab, (struct disklabel *)0, kdbdinfo,
                    252:    kdbdgram, kdbctlrdone, kdbunconf, kdbiodone,
                    253:    kdbonline, kdbgotstatus, NULL, kdbioerror, NULL,
                    254:    "kdb", DRIVENAMES };
                    255: 
                    256: /*
                    257:  * Miscellaneous private variables.
                    258:  */
                    259: char   kdbsr_bits[] = KDBSR_BITS;
                    260: 
                    261: struct uba_device *kdbip[NKDB][MAXUNIT];
                    262:                                /* inverting pointers: ctlr & unit => `Unibus'
                    263:                                   device pointer */
                    264: 
                    265: daddr_t        ra_dsize[NKRA];         /* drive sizes, from on line end packets */
                    266: 
                    267: struct mscp kdbslavereply;     /* get unit status response packet, set
                    268:                                   for kdbslave by kdbunconf, via kdbintr */
                    269: 
                    270: int    kdbwstart, kdbwatch();  /* watchdog timer */
                    271: int    wakeup();
                    272: 
                    273: /*
                    274:  * If kdbprobe is called, return 0 to keep Unibus code from attempting
                    275:  * to use this device. XXX rethink
                    276:  */
                    277: /* ARGSUSED */
                    278: kdbprobe(reg, ctlr)
                    279:        caddr_t reg;
                    280:        int ctlr;
                    281: {
                    282: 
                    283:        return (0);
                    284: }
                    285: 
                    286: /*
                    287:  * Configure in a KDB50 controller.
                    288:  */
                    289: kdbconfig(kdbnum, va, pa, vec)
                    290:        int kdbnum;
                    291:        struct biiregs *va, *pa;
                    292:        int vec;
                    293: {
                    294:        register struct kdbinfo *ki;
                    295: #define mi (&ki->ki_mi)
                    296: 
                    297: #ifdef lint
                    298:        extern int (*kdbint0[])();
                    299: 
                    300:        (*kdbint0[0])(0);       /* this is a config botch */
                    301:        kdbintr(0);
                    302: #endif
                    303: 
                    304:        /*
                    305:         * Set up local KDB status.
                    306:         */
                    307:        ki = &kdbinfo[kdbnum];
                    308:        ki->ki_kdb = (struct kdb_regs *)va;
                    309:        ki->ki_physkdb = (struct kdb_regs *)pa;
                    310:        ki->ki_vec = vec;
                    311:        ki->ki_map =
                    312:            (struct map *)malloc((u_long)(KI_MAPSIZ * sizeof(struct map)),
                    313:            M_DEVBUF, M_NOWAIT);
                    314:        if (ki->ki_map == NULL) {
                    315:                printf("kdb%d: cannot get memory for ptes\n", kdbnum);
                    316:                return;
                    317:        }
                    318:        ki->ki_ptephys = PHYS(long, ki->ki_pte); /* kvtophys(ki->ki_pte) */
                    319:        ki->ki_flags = KDB_ALIVE;
                    320: 
                    321:        /* THE FOLLOWING IS ONLY NEEDED TO CIRCUMVENT A BUG IN rminit */
                    322:        bzero((caddr_t)ki->ki_map, KI_MAPSIZ * sizeof(struct map));
                    323: 
                    324:        rminit(ki->ki_map, (long)KI_PTES, (long)1, "kdb", KI_MAPSIZ);
                    325: 
                    326:        /*
                    327:         * Set up the generic MSCP structures.
                    328:         */
                    329:        mi->mi_md = &kdbmscpdriver;
                    330:        mi->mi_ctlr = kdbnum;   /* also sets ki->ki_ctlr */
                    331:        mi->mi_tab = &ki->ki_tab;
                    332:        mi->mi_ip = kdbip[kdbnum];
                    333:        mi->mi_cmd.mri_size = NCMD;
                    334:        mi->mi_cmd.mri_desc = ki->ki_ca.ca_cmddsc;
                    335:        mi->mi_cmd.mri_ring = ki->ki_cmd;
                    336:        mi->mi_rsp.mri_size = NRSP;
                    337:        mi->mi_rsp.mri_desc = ki->ki_ca.ca_rspdsc;
                    338:        mi->mi_rsp.mri_ring = ki->ki_rsp;
                    339:        mi->mi_wtab.av_forw = mi->mi_wtab.av_back = &mi->mi_wtab;
                    340: #undef mi
                    341: }
                    342: 
                    343: /*
                    344:  * Find a slave.
                    345:  * Note that by the time kdbslave is called, the interrupt vector
                    346:  * for the KDB50 has been set up (so that kdbunconf() will be called).
                    347:  */
                    348: kdbslave(ui)
                    349:        register struct uba_device *ui;
                    350: {
                    351:        register struct kdbinfo *ki;
                    352:        register struct mscp *mp;
                    353:        int next = 0, type, timeout, tries, i;
                    354: 
                    355: #ifdef lint
                    356:        i = 0; i = i;
                    357: #endif
                    358:        /*
                    359:         * Make sure the controller is fully initialised, by waiting
                    360:         * for it if necessary.
                    361:         */
                    362:        ki = &kdbinfo[ui->ui_ctlr];
                    363:        if (ki->ki_state == ST_RUN)
                    364:                goto findunit;
                    365:        tries = 0;
                    366: again:
                    367:        if (kdbinit(ki))
                    368:                return (0);
                    369:        timeout = todr() + 1000;                /* 10 seconds */
                    370:        while (todr() < timeout)
                    371:                if (ki->ki_state == ST_RUN)     /* made it */
                    372:                        goto findunit;
                    373:        if (++tries < 2)
                    374:                goto again;
                    375:        printf("kdb%d: controller hung\n", ki->ki_ctlr);
                    376:        return (0);
                    377: 
                    378:        /*
                    379:         * The controller is all set; go find the unit.  Grab an
                    380:         * MSCP packet and send out a Get Unit Status command, with
                    381:         * the `next unit' modifier if we are looking for a generic
                    382:         * unit.  We set the `in slave' flag so that kdbunconf()
                    383:         * knows to copy the response to `kdbslavereply'.
                    384:         */
                    385: findunit:
                    386:        kdbslavereply.mscp_opcode = 0;
                    387:        ki->ki_flags |= KDB_INSLAVE;
                    388:        if ((mp = mscp_getcp(&ki->ki_mi, MSCP_DONTWAIT)) == NULL)
                    389:                panic("kdbslave");              /* `cannot happen' */
                    390:        mp->mscp_opcode = M_OP_GETUNITST;
                    391:        if (ui->ui_slave == '?') {
                    392:                mp->mscp_unit = next;
                    393:                mp->mscp_modifier = M_GUM_NEXTUNIT;
                    394:        } else {
                    395:                mp->mscp_unit = ui->ui_slave;
                    396:                mp->mscp_modifier = 0;
                    397:        }
                    398:        *mp->mscp_addr |= MSCP_OWN | MSCP_INT;
                    399:        i = ki->ki_kdb->kdb_ip; /* initiate polling */
                    400:        mp = &kdbslavereply;
                    401:        timeout = todr() + 1000;
                    402:        while (todr() < timeout)
                    403:                if (mp->mscp_opcode)
                    404:                        goto gotit;
                    405:        printf("kdb%d: no response to Get Unit Status request\n",
                    406:                ki->ki_ctlr);
                    407:        ki->ki_flags &= ~KDB_INSLAVE;
                    408:        return (0);
                    409: 
                    410: gotit:
                    411:        ki->ki_flags &= ~KDB_INSLAVE;
                    412: 
                    413:        /*
                    414:         * Got a slave response.  If the unit is there, use it.
                    415:         */
                    416:        switch (mp->mscp_status & M_ST_MASK) {
                    417: 
                    418:        case M_ST_SUCCESS:      /* worked */
                    419:        case M_ST_AVAILABLE:    /* found another drive */
                    420:                break;          /* use it */
                    421: 
                    422:        case M_ST_OFFLINE:
                    423:                /*
                    424:                 * Figure out why it is off line.  It may be because
                    425:                 * it is nonexistent, or because it is spun down, or
                    426:                 * for some other reason.
                    427:                 */
                    428:                switch (mp->mscp_status & ~M_ST_MASK) {
                    429: 
                    430:                case M_OFFLINE_UNKNOWN:
                    431:                        /*
                    432:                         * No such drive, and there are none with
                    433:                         * higher unit numbers either, if we are
                    434:                         * using M_GUM_NEXTUNIT.
                    435:                         */
                    436:                        return (0);
                    437: 
                    438:                case M_OFFLINE_UNMOUNTED:
                    439:                        /*
                    440:                         * The drive is not spun up.  Use it anyway.
                    441:                         *
                    442:                         * N.B.: this seems to be a common occurrance
                    443:                         * after a power failure.  The first attempt
                    444:                         * to bring it on line seems to spin it up
                    445:                         * (and thus takes several minutes).  Perhaps
                    446:                         * we should note here that the on-line may
                    447:                         * take longer than usual.
                    448:                         */
                    449:                        break;
                    450: 
                    451:                default:
                    452:                        /*
                    453:                         * In service, or something else equally unusable.
                    454:                         */
                    455:                        printf("kdb%d: unit %d off line:", ki->ki_ctlr,
                    456:                                mp->mscp_unit);
                    457:                        mscp_printevent(mp);
                    458:                        goto try_another;
                    459:                }
                    460:                break;
                    461: 
                    462:        default:
                    463:                printf("kdb%d: unable to get unit status:", ki->ki_ctlr);
                    464:                mscp_printevent(mp);
                    465:                return (0);
                    466:        }
                    467: 
                    468:        /*
                    469:         * Does this ever happen?  What (if anything) does it mean?
                    470:         */
                    471:        if (mp->mscp_unit < next) {
                    472:                printf("kdb%d: unit %d, next %d\n",
                    473:                        ki->ki_ctlr, mp->mscp_unit, next);
                    474:                return (0);
                    475:        }
                    476: 
                    477:        if (mp->mscp_unit >= MAXUNIT) {
                    478:                printf("kdb%d: cannot handle unit number %d (max is %d)\n",
                    479:                        ki->ki_ctlr, mp->mscp_unit, MAXUNIT - 1);
                    480:                return (0);
                    481:        }
                    482: 
                    483:        /*
                    484:         * See if we already handle this drive.
                    485:         * (Only likely if ui->ui_slave=='?'.)
                    486:         */
                    487:        if (kdbip[ki->ki_ctlr][mp->mscp_unit] != NULL)
                    488:                goto try_another;
                    489: 
                    490:        /*
                    491:         * Make sure we know about this kind of drive.
                    492:         * Others say we should treat unknowns as RA81s; I am
                    493:         * not sure this is safe.
                    494:         */
                    495:        type = mp->mscp_guse.guse_drivetype;
                    496:        if (type >= NTYPES || kdbtypes[type].ut_name == 0) {
                    497:                register long id = mp->mscp_guse.guse_mediaid;
                    498: 
                    499:                printf("kdb%d: unit %d: media ID `", ki->ki_ctlr,
                    500:                        mp->mscp_unit);
                    501:                printf("%c%c %c%c%c%d",
                    502:                        MSCP_MID_CHAR(4, id), MSCP_MID_CHAR(3, id),
                    503:                        MSCP_MID_CHAR(2, id), MSCP_MID_CHAR(1, id),
                    504:                        MSCP_MID_CHAR(0, id), MSCP_MID_NUM(id));
                    505:                printf("' is of unknown type %d; ignored\n", type);
                    506: try_another:
                    507:                if (ui->ui_slave != '?')
                    508:                        return (0);
                    509:                next = mp->mscp_unit + 1;
                    510:                goto findunit;
                    511:        }
                    512: 
                    513:        /*
                    514:         * Voila!
                    515:         */
                    516:        ui->ui_type = type;
                    517:        ui->ui_flags = 0;       /* not on line, nor anything else */
                    518:        ui->ui_slave = mp->mscp_unit;
                    519:        return (1);
                    520: }
                    521: 
                    522: /*
                    523:  * Attach a found slave.  Make sure the watchdog timer is running.
                    524:  * If this disk is being profiled, fill in the `wpms' value (used by
                    525:  * what?).  Set up the inverting pointer, and attempt to bring the
                    526:  * drive on line.
                    527:  */
                    528: kdbattach(ui)
                    529:        register struct uba_device *ui;
                    530: {
                    531: 
                    532:        if (kdbwstart == 0) {
                    533:                timeout(kdbwatch, (caddr_t)0, hz);
                    534:                kdbwstart++;
                    535:        }
                    536:        if (ui->ui_dk >= 0)
                    537:                dk_wpms[ui->ui_dk] = (60 * 31 * 256);   /* approx */
                    538:        kdbip[ui->ui_ctlr][ui->ui_slave] = ui;
                    539:        (void) kdb_bringonline(ui, 1);
                    540:        /* should we get its status too? */
                    541: }
                    542: 
                    543: /*
                    544:  * Initialise a KDB50.  Return true iff something goes wrong.
                    545:  */
                    546: kdbinit(ki)
                    547:        register struct kdbinfo *ki;
                    548: {
                    549:        register struct kdb_regs *ka = ki->ki_kdb;
                    550:        int timo;
                    551: 
                    552:        /*
                    553:         * While we are thinking about it, reset the next command
                    554:         * and response indicies.
                    555:         */
                    556:        ki->ki_mi.mi_cmd.mri_next = 0;
                    557:        ki->ki_mi.mi_rsp.mri_next = 0;
                    558: 
                    559:        /*
                    560:         * Start up the hardware initialisation sequence.
                    561:         */
                    562: #define        STEP0MASK (KDB_ERR | KDB_STEP4 | KDB_STEP3 | KDB_STEP2 | KDB_STEP1)
                    563: 
                    564:        ki->ki_state = ST_IDLE; /* in case init fails */
                    565: 
                    566:        bi_reset(&ka->kdb_bi);  /* reset bi node (but not the BI itself) */
                    567: 
                    568:        timo = todr() + 1000;
                    569:        while ((ka->kdb_sa & STEP0MASK) == 0) {
                    570:                if (todr() > timo) {
                    571:                        printf("kdb%d: timeout during init\n", ki->ki_ctlr);
                    572:                        return (-1);
                    573:                }
                    574:        }
                    575:        if ((ka->kdb_sa & STEP0MASK) != KDB_STEP1) {
                    576:                printf("kdb%d: init failed, sa=%b\n", ki->ki_ctlr,
                    577:                        ka->kdb_sa, kdbsr_bits);
                    578:                return (-1);
                    579:        }
                    580: 
                    581:        /*
                    582:         * Success!  Record new state, and start step 1 initialisation.
                    583:         * The rest is done in the interrupt handler.
                    584:         */
                    585:        ki->ki_state = ST_STEP1;
                    586:        ka->kdb_bi.bi_intrdes = 1 << mastercpu;
                    587: #ifdef unneeded /* is it? */
                    588:        ka->kdb_bi.bi_csr = (ka->kdb_bi.bi_csr&~BICSR_ARB_MASK)|BICSR_ARB_???;
                    589: #endif
                    590:        ka->kdb_bi.bi_bcicsr |= BCI_STOPEN | BCI_IDENTEN | BCI_UINTEN |
                    591:                BCI_INTEN;
                    592: 
                    593: /* I THINK THIS IS WRONG */
                    594: /* Mach uses 0x601d0, which includes IPL16, but 1d0 is IPL17, nexzvec...? */
                    595:        ka->kdb_bi.bi_eintrcsr = BIEIC_IPL15 | ki->ki_vec;      /* ??? */
                    596: /* END I THINK WRONG */
                    597: 
                    598:        ka->kdb_bi.bi_uintrcsr = ki->ki_vec;
                    599:        ka->kdb_sw = KDB_ERR | (NCMDL2 << 11) | (NRSPL2 << 8) | KDB_IE |
                    600:                (ki->ki_vec >> 2);
                    601:        return (0);
                    602: }
                    603: 
                    604: /*
                    605:  * Open a drive.
                    606:  */
                    607: /*ARGSUSED*/
                    608: kdbopen(dev, flag)
                    609:        dev_t dev;
                    610:        int flag;
                    611: {
                    612:        register int unit;
                    613:        register struct uba_device *ui;
                    614:        register struct kdbinfo *ki;
                    615:        int s;
                    616: 
                    617:        /*
                    618:         * Make sure this is a reasonable open request.
                    619:         */
                    620:        unit = kdbunit(dev);
                    621:        if (unit >= NKRA || (ui = kdbdinfo[unit]) == 0 || ui->ui_alive == 0)
                    622:                return (ENXIO);
                    623: 
                    624:        /*
                    625:         * Make sure the controller is running, by (re)initialising it if
                    626:         * necessary.
                    627:         */
                    628:        ki = &kdbinfo[ui->ui_ctlr];
                    629:        s = spl5();
                    630:        if (ki->ki_state != ST_RUN) {
                    631:                if (ki->ki_state == ST_IDLE && kdbinit(ki)) {
                    632:                        splx(s);
                    633:                        return (EIO);
                    634:                }
                    635:                /*
                    636:                 * In case it does not come up, make sure we will be
                    637:                 * restarted in 10 seconds.  This corresponds to the
                    638:                 * 10 second timeouts in kdbprobe() and kdbslave().
                    639:                 */
                    640:                ki->ki_flags |= KDB_DOWAKE;
                    641:                timeout(wakeup, (caddr_t)&ki->ki_flags, 10 * hz);
                    642:                sleep((caddr_t)&ki->ki_flags, PRIBIO);
                    643:                if (ki->ki_state != ST_RUN) {
                    644:                        splx(s);
                    645:                        printf("kdb%d: controller hung\n", ui->ui_ctlr);
                    646:                        return (EIO);
                    647:                }
                    648:                untimeout(wakeup, (caddr_t)&ki->ki_flags);
                    649:        }
                    650:        if ((ui->ui_flags & UNIT_ONLINE) == 0) {
                    651:                /*
                    652:                 * Bring the drive on line so we can find out how
                    653:                 * big it is.  If it is not spun up, it will not
                    654:                 * come on line; this cannot really be considered
                    655:                 * an `error condition'.
                    656:                 */
                    657:                if (kdb_bringonline(ui, 0)) {
                    658:                        splx(s);
                    659:                        printf("%s%d: drive will not come on line\n",
                    660:                                kdbdriver.ud_dname, unit);
                    661:                        return (EIO);
                    662:                }
                    663:        }
                    664:        splx(s);
                    665:        return (0);
                    666: }
                    667: 
                    668: /*
                    669:  * Bring a drive on line.  In case it fails to respond, we set
                    670:  * a timeout on it.  The `nosleep' parameter should be set if
                    671:  * we are to spin-wait; otherwise this must be called at spl5().
                    672:  */
                    673: kdb_bringonline(ui, nosleep)
                    674:        register struct uba_device *ui;
                    675:        int nosleep;
                    676: {
                    677:        register struct kdbinfo *ki = &kdbinfo[ui->ui_ctlr];
                    678:        register struct mscp *mp;
                    679:        int i;
                    680: 
                    681:        if (nosleep) {
                    682:                mp = mscp_getcp(&ki->ki_mi, MSCP_DONTWAIT);
                    683:                if (mp == NULL)
                    684:                        return (-1);
                    685:        } else
                    686:                mp = mscp_getcp(&ki->ki_mi, MSCP_WAIT);
                    687:        mp->mscp_opcode = M_OP_ONLINE;
                    688:        mp->mscp_unit = ui->ui_slave;
                    689:        mp->mscp_cmdref = (long)&ui->ui_flags;
                    690:        *mp->mscp_addr |= MSCP_OWN | MSCP_INT;
                    691:        i = ki->ki_kdb->kdb_ip;
                    692: 
                    693:        if (nosleep) {
                    694:                i = todr() + 1000;
                    695:                while ((ui->ui_flags & UNIT_ONLINE) == 0)
                    696:                        if (todr() > i)
                    697:                                return (-1);
                    698:        } else {
                    699:                timeout(wakeup, (caddr_t)&ui->ui_flags, 10 * hz);
                    700:                sleep((caddr_t)&ui->ui_flags, PRIBIO);
                    701:                if ((ui->ui_flags & UNIT_ONLINE) == 0)
                    702:                        return (-1);
                    703:                untimeout(wakeup, (caddr_t)&ui->ui_flags);
                    704:        }
                    705:        return (0);     /* made it */
                    706: }
                    707: 
                    708: /*
                    709:  * Queue a transfer request, and if possible, hand it to the controller.
                    710:  *
                    711:  * This routine is broken into two so that the internal version
                    712:  * kdbstrat1() can be called by the (nonexistent, as yet) bad block
                    713:  * revectoring routine.
                    714:  */
                    715: kdbstrategy(bp)
                    716:        register struct buf *bp;
                    717: {
                    718:        register int unit;
                    719:        register struct uba_device *ui;
                    720:        register struct size *st;
                    721:        daddr_t sz, maxsz;
                    722: 
                    723:        /*
                    724:         * Make sure this is a reasonable drive to use.
                    725:         */
                    726:        if ((unit = kdbunit(bp->b_dev)) >= NKRA ||
                    727:            (ui = kdbdinfo[unit]) == NULL || ui->ui_alive == 0) {
                    728:                bp->b_error = ENXIO;
                    729:                bp->b_flags |= B_ERROR;
                    730:                biodone(bp);
                    731:                return;
                    732:        }
                    733: 
                    734:        /*
                    735:         * Determine the size of the transfer, and make sure it is
                    736:         * within the boundaries of the drive.
                    737:         */
                    738:        sz = (bp->b_bcount + 511) >> 9;
                    739:        st = &kdbtypes[ui->ui_type].ut_sizes[kdbpart(bp->b_dev)];
                    740:        if ((maxsz = st->nblocks) < 0)
                    741:                maxsz = ra_dsize[unit] - st->blkoff;
                    742:        if (bp->b_blkno < 0 || bp->b_blkno + sz > maxsz ||
                    743:            st->blkoff >= ra_dsize[unit]) {
                    744:                /* if exactly at end of disk, return an EOF */
                    745:                if (bp->b_blkno == maxsz)
                    746:                        bp->b_resid = bp->b_bcount;
                    747:                else {
                    748:                        bp->b_error = EINVAL;
                    749:                        bp->b_flags |= B_ERROR;
                    750:                }
                    751:                biodone(bp);
                    752:                return;
                    753:        }
                    754:        kdbstrat1(bp);
                    755: }
                    756: 
                    757: /*
                    758:  * Work routine for kdbstrategy.
                    759:  */
                    760: kdbstrat1(bp)
                    761:        register struct buf *bp;
                    762: {
                    763:        register int unit = kdbunit(bp->b_dev);
                    764:        register struct buf *dp;
                    765:        register struct kdbinfo *ki;
                    766:        struct uba_device *ui;
                    767:        int s;
                    768: 
                    769:        /*
                    770:         * Append the buffer to the drive queue, and if it is not
                    771:         * already there, the drive to the controller queue.  (However,
                    772:         * if the drive queue is marked to be requeued, we must be
                    773:         * awaiting an on line or get unit status command; in this
                    774:         * case, leave it off the controller queue.)
                    775:         */
                    776:        ui = kdbdinfo[unit];
                    777:        ki = &kdbinfo[ui->ui_ctlr];
                    778:        dp = &kdbutab[unit];
                    779:        s = spl5();
                    780:        APPEND(bp, dp, av_forw);
                    781:        if (dp->b_active == 0 && (ui->ui_flags & UNIT_REQUEUE) == 0) {
                    782:                APPEND(dp, &ki->ki_tab, b_forw);
                    783:                dp->b_active++;
                    784:        }
                    785: 
                    786:        /*
                    787:         * Start activity on the controller.
                    788:         */
                    789:        kdbstart(ki);
                    790:        splx(s);
                    791: }
                    792: 
                    793: /*
                    794:  * Find the physical address of some contiguous PTEs that map the
                    795:  * transfer described in `bp', creating them (by copying) if
                    796:  * necessary.  Store the physical base address of the map through
                    797:  * mapbase, and the page offset through offset, and any resource
                    798:  * information in *info (or 0 if none).
                    799:  *
                    800:  * If we cannot allocate space, return a nonzero status.
                    801:  */
                    802: int
                    803: kdbmap(ki, bp, mapbase, offset, info)
                    804:        struct kdbinfo *ki;
                    805:        register struct buf *bp;
                    806:        long *mapbase, *offset;
                    807:        int *info;
                    808: {
                    809:        register struct pte *spte, *dpte;
                    810:        register struct proc *rp;
                    811:        register int i, a, o;
                    812:        u_int v;
                    813:        int npf;
                    814: 
                    815:        o = (int)bp->b_un.b_addr & PGOFSET;
                    816: 
                    817:        /* handle contiguous cases */
                    818:        if ((bp->b_flags & B_PHYS) == 0) {
                    819:                spte = kvtopte(bp->b_un.b_addr);
                    820:                kdbstats.ks_sys++;
                    821:                *mapbase = PHYS(long, spte);
                    822:                *offset = o;
                    823:                *info = 0;
                    824:                return (0);
                    825:        }
                    826:        if (bp->b_flags & B_PAGET) {
                    827:                spte = &Usrptmap[btokmx((struct pte *)bp->b_un.b_addr)];
                    828: if (spte->pg_v == 0) panic("kdbmap");
                    829:                kdbstats.ks_paget++;
                    830:                *mapbase = PHYS(long, spte);
                    831:                *offset = o;
                    832:                *info = 0;
                    833:                return (0);
                    834:        }
                    835: 
                    836:        /* potentially discontiguous or invalid ptes */
                    837:        v = btop(bp->b_un.b_addr);
                    838:        rp = bp->b_flags & B_DIRTY ? &proc[2] : bp->b_proc;
                    839:        if (bp->b_flags & B_UAREA)
                    840:                spte = &rp->p_addr[v];
                    841:        else
                    842:                spte = vtopte(rp, v);
                    843:        npf = btoc(bp->b_bcount + o);
                    844: 
                    845: #ifdef notdef
                    846:        /*
                    847:         * The current implementation of the VM system requires
                    848:         * that all of these be done with a copy.  Even if the
                    849:         * PTEs could be used now, they may be snatched out from
                    850:         * under us later.  It would be nice if we could stop that....
                    851:         */
                    852: 
                    853:        /* check for invalid */
                    854:        /* CONSIDER CHANGING VM TO VALIDATE PAGES EARLIER */
                    855:        for (dpte = spte, i = npf; --i >= 0; dpte++)
                    856:                if (dpte->pg_v == 0)
                    857:                        goto copy1;
                    858:        /*
                    859:         * Check for discontiguous physical pte addresses.  It is
                    860:         * not necessary to check each pte, since they come in clumps
                    861:         * of pages.
                    862:         */
                    863:        i = howmany(npf + (((int)spte & PGOFSET) / sizeof (*spte)), NPTEPG);
                    864:        /* often i==1, and we can avoid work */
                    865:        if (--i > 0) {
                    866:                dpte = kvtopte(spte);
                    867:                a = dpte->pg_pfnum;
                    868:                while (--i >= 0)
                    869:                        if ((++dpte)->pg_pfnum != ++a)
                    870:                                goto copy2;
                    871:        }
                    872: 
                    873:        /* made it */
                    874:        kdbstats.ks_contig++;
                    875:        *mapbase = kvtophys(spte);
                    876:        *offset = o;
                    877:        *info = 0;
                    878:        return (0);
                    879: 
                    880: copy1:
                    881:        kdbstats.ks_inval++;            /* temp */
                    882: copy2:
                    883: #endif /* notdef */
                    884:        kdbstats.ks_copies++;
                    885:        i = npf + 1;
                    886:        if ((a = rmalloc(ki->ki_map, (long)i)) == 0) {
                    887:                kdbstats.ks_mapwait++;
                    888:                return (-1);
                    889:        }
                    890:        *info = (i << 16) | a;
                    891:        a--;
                    892:        /* if offset > PGOFSET, btop(offset) indexes mapbase */
                    893:        *mapbase = ki->ki_ptephys;
                    894:        *offset = (a << PGSHIFT) | o;
                    895:        dpte = &ki->ki_pte[a];
                    896:        while (--i > 0)
                    897:                *(int *)dpte++ = PG_V | *(int *)spte++;
                    898:        *(int *)dpte = 0;
                    899:        return (0);
                    900: }
                    901: 
                    902: #define        KDBFREE(ki, info) if (info) \
                    903:        rmfree((ki)->ki_map, (long)((info) >> 16), (long)((info) & 0xffff))
                    904: 
                    905: /*
                    906:  * Start up whatever transfers we can find.
                    907:  * Note that kdbstart() must be called at spl5().
                    908:  */
                    909: kdbstart(ki)
                    910:        register struct kdbinfo *ki;
                    911: {
                    912:        register struct buf *bp, *dp;
                    913:        register struct mscp *mp;
                    914:        register struct uba_device *ui;
                    915:        long mapbase, offset;
                    916:        int info, ncmd = 0;
                    917: 
                    918:        /*
                    919:         * If it is not running, try (again and again...) to initialise
                    920:         * it.  If it is currently initialising just ignore it for now.
                    921:         */
                    922:        if (ki->ki_state != ST_RUN) {
                    923:                if (ki->ki_state == ST_IDLE && kdbinit(ki))
                    924:                        printf("kdb%d: still hung\n", ki->ki_ctlr);
                    925:                return;
                    926:        }
                    927: 
                    928: loop:
                    929:        /* if insufficient credit, avoid overhead */
                    930:        if (ki->ki_mi.mi_credits <= MSCP_MINCREDITS)
                    931:                goto out;
                    932: 
                    933:        /*
                    934:         * Service the drive at the head of the queue.  It may not
                    935:         * need anything; eventually this will finish up the close
                    936:         * protocol, but that is yet to be implemented here.
                    937:         */
                    938:        if ((dp = ki->ki_tab.b_actf) == NULL)
                    939:                goto out;
                    940:        if ((bp = dp->b_actf) == NULL) {
                    941:                dp->b_active = 0;
                    942:                ki->ki_tab.b_actf = dp->b_forw;
                    943:                goto loop;
                    944:        }
                    945: 
                    946:        if (ki->ki_kdb->kdb_sa & KDB_ERR) {     /* ctlr fatal error */
                    947:                kdbsaerror(ki);
                    948:                goto out;
                    949:        }
                    950: 
                    951:         /* find or create maps for this transfer */
                    952:         if (kdbmap(ki, bp, &mapbase, &offset, &info))
                    953:                goto out;       /* effectively, resource wait */
                    954: 
                    955:        /*
                    956:         * Get an MSCP packet, then figure out what to do.  If
                    957:         * we cannot get a command packet, the command ring may
                    958:         * be too small:  We should have at least as many command
                    959:         * packets as credits, for best performance.
                    960:         */
                    961:        if ((mp = mscp_getcp(&ki->ki_mi, MSCP_DONTWAIT)) == NULL) {
                    962:                if (ki->ki_mi.mi_credits > MSCP_MINCREDITS &&
                    963:                    (ki->ki_flags & KDB_GRIPED) == 0) {
                    964:                        log(LOG_NOTICE, "kdb%d: command ring too small\n",
                    965:                                ki->ki_ctlr);
                    966:                        ki->ki_flags |= KDB_GRIPED;/* complain only once */
                    967:                }
                    968:                KDBFREE(ki, info);
                    969:                goto out;
                    970:        }
                    971: 
                    972:        /*
                    973:         * Bring the drive on line if it is not already.  Get its status
                    974:         * if we do not already have it.  Otherwise just start the transfer.
                    975:         */
                    976:        ui = kdbdinfo[kdbunit(bp->b_dev)];
                    977:        if ((ui->ui_flags & UNIT_ONLINE) == 0) {
                    978:                mp->mscp_opcode = M_OP_ONLINE;
                    979:                goto common;
                    980:        }
                    981:        if ((ui->ui_flags & UNIT_HAVESTATUS) == 0) {
                    982:                mp->mscp_opcode = M_OP_GETUNITST;
                    983: common:
                    984: if (ui->ui_flags & UNIT_REQUEUE) panic("kdbstart");
                    985:                /*
                    986:                 * Take the drive off the controller queue.  When the
                    987:                 * command finishes, make sure the drive is requeued.
                    988:                 * Give up any mapping (not needed now).  This last is
                    989:                 * not efficient, but is rare.
                    990:                 */
                    991:                KDBFREE(ki, info);
                    992:                ki->ki_tab.b_actf = dp->b_forw;
                    993:                dp->b_active = 0;
                    994:                ui->ui_flags |= UNIT_REQUEUE;
                    995:                mp->mscp_unit = ui->ui_slave;
                    996:                *mp->mscp_addr |= MSCP_OWN | MSCP_INT;
                    997:                ncmd++;
                    998:                goto loop;
                    999:        }
                   1000: 
                   1001:        mp->mscp_opcode = (bp->b_flags & B_READ) ? M_OP_READ : M_OP_WRITE;
                   1002:        mp->mscp_unit = ui->ui_slave;
                   1003:        mp->mscp_seq.seq_lbn = bp->b_blkno +
                   1004:                kdbtypes[ui->ui_type].ut_sizes[kdbpart(bp->b_dev)].blkoff;
                   1005:        mp->mscp_seq.seq_bytecount = bp->b_bcount;
                   1006: 
                   1007:        mp->mscp_seq.seq_buffer = offset | KDB_MAP;
                   1008:        mp->mscp_seq.seq_mapbase = mapbase;
                   1009: 
                   1010:        /* profile the drive */
                   1011:        if (ui->ui_dk >= 0) {
                   1012:                dk_busy |= 1 << ui->ui_dk;
                   1013:                dk_xfer[ui->ui_dk]++;
                   1014:                dk_wds[ui->ui_dk] += bp->b_bcount >> 6;
                   1015:        }
                   1016: 
                   1017:        /*
                   1018:         * Fill in the rest of the MSCP packet and move the buffer to the
                   1019:         * I/O wait queue.
                   1020:         */
                   1021:        mscp_go(&ki->ki_mi, mp, info);
                   1022:        ncmd++;                 /* note the transfer */
                   1023:        ki->ki_tab.b_active++;  /* another one going */
                   1024:        goto loop;
                   1025: 
                   1026: out:
                   1027:        if (ncmd >= KS_MAXC)
                   1028:                ncmd = KS_MAXC - 1;
                   1029:        kdbstats.ks_cmd[ncmd]++;
                   1030:        if (ncmd)               /* start some transfers */
                   1031:                ncmd = ki->ki_kdb->kdb_ip;
                   1032: }
                   1033: 
                   1034: /* ARGSUSED */
                   1035: kdbiodone(mi, bp, info)
                   1036:        struct mscp_info *mi;
                   1037:        struct buf *bp;
                   1038:        int info;
                   1039: {
                   1040:        register struct kdbinfo *ki = &kdbinfo[mi->mi_ctlr];
                   1041: 
                   1042:        KDBFREE(ki, info);
                   1043:        biodone(bp);
                   1044:        ki->ki_tab.b_active--;  /* another one done */
                   1045: }
                   1046: 
                   1047: /*
                   1048:  * The error bit was set in the controller status register.  Gripe,
                   1049:  * reset the controller, requeue pending transfers.
                   1050:  */
                   1051: kdbsaerror(ki)
                   1052:        register struct kdbinfo *ki;
                   1053: {
                   1054: 
                   1055:        printf("kdb%d: controller error, sa=%b\n", ki->ki_ctlr,
                   1056:                ki->ki_kdb->kdb_sa, kdbsr_bits);
                   1057:        mscp_requeue(&ki->ki_mi);
                   1058:        (void) kdbinit(ki);
                   1059: }
                   1060: 
                   1061: /*
                   1062:  * Interrupt routine.  Depending on the state of the controller,
                   1063:  * continue initialisation, or acknowledge command and response
                   1064:  * interrupts, and process responses.
                   1065:  */
                   1066: kdbintr(ctlr)
                   1067:        int ctlr;
                   1068: {
                   1069:        register struct kdbinfo *ki = &kdbinfo[ctlr];
                   1070:        register struct kdb_regs *kdbaddr = ki->ki_kdb;
                   1071:        register struct mscp *mp;
                   1072:        register int i;
                   1073: 
                   1074:        ki->ki_wticks = 0;      /* reset interrupt watchdog */
                   1075: 
                   1076:        /*
                   1077:         * Combinations during steps 1, 2, and 3: STEPnMASK
                   1078:         * corresponds to which bits should be tested;
                   1079:         * STEPnGOOD corresponds to the pattern that should
                   1080:         * appear after the interrupt from STEPn initialisation.
                   1081:         * All steps test the bits in ALLSTEPS.
                   1082:         */
                   1083: #define        ALLSTEPS        (KDB_ERR|KDB_STEP4|KDB_STEP3|KDB_STEP2|KDB_STEP1)
                   1084: 
                   1085: #define        STEP1MASK       (ALLSTEPS | KDB_IE | KDB_NCNRMASK)
                   1086: #define        STEP1GOOD       (KDB_STEP2 | KDB_IE | (NCMDL2 << 3) | NRSPL2)
                   1087: 
                   1088: #define        STEP2MASK       (ALLSTEPS | KDB_IE | KDB_IVECMASK)
                   1089: #define        STEP2GOOD       (KDB_STEP3 | KDB_IE | (ki->ki_vec >> 2))
                   1090: 
                   1091: #define        STEP3MASK       ALLSTEPS
                   1092: #define        STEP3GOOD       KDB_STEP4
                   1093: 
                   1094:        switch (ki->ki_state) {
                   1095: 
                   1096:        case ST_IDLE:
                   1097:                /*
                   1098:                 * Ignore unsolicited interrupts.
                   1099:                 */
                   1100:                log(LOG_WARNING, "kdb%d: stray intr\n", ctlr);
                   1101:                return;
                   1102: 
                   1103:        case ST_STEP1:
                   1104:                /*
                   1105:                 * Begin step two initialisation.
                   1106:                 */
                   1107:                if ((kdbaddr->kdb_sa & STEP1MASK) != STEP1GOOD) {
                   1108:                        i = 1;
                   1109: initfailed:
                   1110:                        printf("kdb%d: init step %d failed, sa=%b\n",
                   1111:                                ctlr, i, kdbaddr->kdb_sa, kdbsr_bits);
                   1112:                        ki->ki_state = ST_IDLE;
                   1113:                        if (ki->ki_flags & KDB_DOWAKE) {
                   1114:                                ki->ki_flags &= ~KDB_DOWAKE;
                   1115:                                wakeup((caddr_t)&ki->ki_flags);
                   1116:                        }
                   1117:                        return;
                   1118:                }
                   1119:                kdbaddr->kdb_sw = PHYS(int, &ki->ki_ca.ca_rspdsc[0]);
                   1120:                ki->ki_state = ST_STEP2;
                   1121:                return;
                   1122: 
                   1123:        case ST_STEP2:
                   1124:                /*
                   1125:                 * Begin step 3 initialisation.
                   1126:                 */
                   1127:                if ((kdbaddr->kdb_sa & STEP2MASK) != STEP2GOOD) {
                   1128:                        i = 2;
                   1129:                        goto initfailed;
                   1130:                }
                   1131:                kdbaddr->kdb_sw = PHYS(int, &ki->ki_ca.ca_rspdsc[0]) >> 16;
                   1132:                ki->ki_state = ST_STEP3;
                   1133:                return;
                   1134: 
                   1135:        case ST_STEP3:
                   1136:                /*
                   1137:                 * Set controller characteristics (finish initialisation).
                   1138:                 */
                   1139:                if ((kdbaddr->kdb_sa & STEP3MASK) != STEP3GOOD) {
                   1140:                        i = 3;
                   1141:                        goto initfailed;
                   1142:                }
                   1143:                i = kdbaddr->kdb_sa & 0xff;
                   1144:                if (i != ki->ki_micro) {
                   1145:                        ki->ki_micro = i;
                   1146:                        printf("kdb%d: version %d model %d\n",
                   1147:                                ctlr, i & 0xf, i >> 4);
                   1148:                }
                   1149: 
                   1150:                kdbaddr->kdb_sw = KDB_GO;
                   1151: 
                   1152:                /* initialise hardware data structures */
                   1153:                for (i = 0, mp = ki->ki_rsp; i < NRSP; i++, mp++) {
                   1154:                        ki->ki_ca.ca_rspdsc[i] = MSCP_OWN | MSCP_INT |
                   1155:                                PHYS(long, &ki->ki_rsp[i].mscp_cmdref);
                   1156:                        mp->mscp_addr = &ki->ki_ca.ca_rspdsc[i];
                   1157:                        mp->mscp_msglen = MSCP_MSGLEN;
                   1158:                }
                   1159:                for (i = 0, mp = ki->ki_cmd; i < NCMD; i++, mp++) {
                   1160:                        ki->ki_ca.ca_cmddsc[i] = MSCP_INT |
                   1161:                                PHYS(long, &ki->ki_cmd[i].mscp_cmdref);
                   1162:                        mp->mscp_addr = &ki->ki_ca.ca_cmddsc[i];
                   1163:                        mp->mscp_msglen = MSCP_MSGLEN;
                   1164:                }
                   1165: 
                   1166:                /*
                   1167:                 * Before we can get a command packet, we need some
                   1168:                 * credits.  Fake some up to keep mscp_getcp() happy,
                   1169:                 * get a packet, and cancel all credits (the right
                   1170:                 * number should come back in the response to the
                   1171:                 * SCC packet).
                   1172:                 */
                   1173:                ki->ki_mi.mi_credits = MSCP_MINCREDITS + 1;
                   1174:                mp = mscp_getcp(&ki->ki_mi, MSCP_DONTWAIT);
                   1175:                if (mp == NULL) /* `cannot happen' */
                   1176:                        panic("kdbintr");
                   1177:                ki->ki_mi.mi_credits = 0;
                   1178:                mp->mscp_opcode = M_OP_SETCTLRC;
                   1179:                mp->mscp_unit = 0;
                   1180:                mp->mscp_sccc.sccc_ctlrflags = M_CF_ATTN | M_CF_MISC |
                   1181:                        M_CF_THIS;
                   1182:                *mp->mscp_addr |= MSCP_OWN | MSCP_INT;
                   1183:                i = kdbaddr->kdb_ip;
                   1184:                ki->ki_state = ST_SETCHAR;
                   1185:                return;
                   1186: 
                   1187:        case ST_SETCHAR:
                   1188:        case ST_RUN:
                   1189:                /*
                   1190:                 * Handle Set Ctlr Characteristics responses and operational
                   1191:                 * responses (via mscp_dorsp).
                   1192:                 */
                   1193:                break;
                   1194: 
                   1195:        default:
                   1196:                log(LOG_ERR, "kdb%d: driver bug, state %d\n", ctlr,
                   1197:                        ki->ki_state);
                   1198:                return;
                   1199:        }
                   1200: 
                   1201:        if (kdbaddr->kdb_sa & KDB_ERR) {/* ctlr fatal error */
                   1202:                kdbsaerror(ki);
                   1203:                return;
                   1204:        }
                   1205: 
                   1206:        /*
                   1207:         * Handle buffer purge requests.
                   1208:         * KDB DOES NOT HAVE BDPs
                   1209:         */
                   1210:        if (ki->ki_ca.ca_bdp) {
                   1211:                printf("kdb%d: purge bdp %d\n", ctlr, ki->ki_ca.ca_bdp);
                   1212:                panic("kdb purge");
                   1213:        }
                   1214: 
                   1215:        /*
                   1216:         * Check for response and command ring transitions.
                   1217:         */
                   1218:        if (ki->ki_ca.ca_rspint) {
                   1219:                ki->ki_ca.ca_rspint = 0;
                   1220:                mscp_dorsp(&ki->ki_mi);
                   1221:        }
                   1222:        if (ki->ki_ca.ca_cmdint) {
                   1223:                ki->ki_ca.ca_cmdint = 0;
                   1224:                MSCP_DOCMD(&ki->ki_mi);
                   1225:        }
                   1226:        if (ki->ki_tab.b_actf != NULL)
                   1227:                kdbstart(ki);
                   1228: }
                   1229: 
                   1230: /*
                   1231:  * Handle an error datagram.  All we do now is decode it.
                   1232:  */
                   1233: kdbdgram(mi, mp)
                   1234:        struct mscp_info *mi;
                   1235:        struct mscp *mp;
                   1236: {
                   1237: 
                   1238:        mscp_decodeerror(mi->mi_md->md_mname, mi->mi_ctlr, mp);
                   1239: }
                   1240: 
                   1241: /*
                   1242:  * The Set Controller Characteristics command finished.
                   1243:  * Record the new state of the controller.
                   1244:  */
                   1245: kdbctlrdone(mi, mp)
                   1246:        struct mscp_info *mi;
                   1247:        struct mscp *mp;
                   1248: {
                   1249:        register struct kdbinfo *ki = &kdbinfo[mi->mi_ctlr];
                   1250: 
                   1251:        if ((mp->mscp_status & M_ST_MASK) == M_ST_SUCCESS)
                   1252:                ki->ki_state = ST_RUN;
                   1253:        else {
                   1254:                printf("kdb%d: SETCTLRC failed, status 0x%x\n",
                   1255:                        ki->ki_ctlr, mp->mscp_status);
                   1256:                ki->ki_state = ST_IDLE;
                   1257:        }
                   1258:        if (ki->ki_flags & KDB_DOWAKE) {
                   1259:                ki->ki_flags &= ~KDB_DOWAKE;
                   1260:                wakeup((caddr_t)&ki->ki_flags);
                   1261:        }
                   1262: }
                   1263: 
                   1264: /*
                   1265:  * Received a response from an as-yet unconfigured drive.  Configure it
                   1266:  * in, if possible.
                   1267:  */
                   1268: kdbunconf(mi, mp)
                   1269:        struct mscp_info *mi;
                   1270:        register struct mscp *mp;
                   1271: {
                   1272: 
                   1273:        /*
                   1274:         * If it is a slave response, copy it to kdbslavereply for
                   1275:         * kdbslave() to look at.
                   1276:         */
                   1277:        if (mp->mscp_opcode == (M_OP_GETUNITST | M_OP_END) &&
                   1278:            (kdbinfo[mi->mi_ctlr].ki_flags & KDB_INSLAVE) != 0) {
                   1279:                kdbslavereply = *mp;
                   1280:                return (MSCP_DONE);
                   1281:        }
                   1282: 
                   1283:        /*
                   1284:         * Otherwise, it had better be an available attention response.
                   1285:         */
                   1286:        if (mp->mscp_opcode != M_OP_AVAILATTN)
                   1287:                return (MSCP_FAILED);
                   1288: 
                   1289:        /* do what autoconf does */
                   1290:        return (MSCP_FAILED);   /* not yet */
                   1291: }
                   1292: 
                   1293: /*
                   1294:  * A drive came on line.  Check its type and size.  Return DONE if
                   1295:  * we think the drive is truly on line.  In any case, awaken anyone
                   1296:  * sleeping on the drive on-line-ness.
                   1297:  */
                   1298: kdbonline(ui, mp)
                   1299:        register struct uba_device *ui;
                   1300:        struct mscp *mp;
                   1301: {
                   1302:        register int type;
                   1303: 
                   1304:        wakeup((caddr_t)&ui->ui_flags);
                   1305:        if ((mp->mscp_status & M_ST_MASK) != M_ST_SUCCESS) {
                   1306:                printf("kdb%d: attempt to bring %s%d on line failed:",
                   1307:                        ui->ui_ctlr, kdbdriver.ud_dname, ui->ui_unit);
                   1308:                mscp_printevent(mp);
                   1309:                return (MSCP_FAILED);
                   1310:        }
                   1311: 
                   1312:        type = mp->mscp_onle.onle_drivetype;
                   1313:        if (type >= NTYPES || kdbtypes[type].ut_name == 0) {
                   1314:                printf("kdb%d: %s%d: unknown type %d\n",
                   1315:                        ui->ui_ctlr, kdbdriver.ud_dname, ui->ui_unit, type);
                   1316:                return (MSCP_FAILED);
                   1317:        }
                   1318:        /*
                   1319:         * Note any change of types.  Not sure if we should do
                   1320:         * something special about them, or if so, what....
                   1321:         */
                   1322:        if (type != ui->ui_type) {
                   1323:                printf("%s%d: changed types! was %s\n",
                   1324:                        kdbdriver.ud_dname, ui->ui_unit,
                   1325:                        kdbtypes[ui->ui_type].ut_name);
                   1326:                ui->ui_type = type;
                   1327:        }
                   1328:        ra_dsize[ui->ui_unit] = (daddr_t) mp->mscp_onle.onle_unitsize;
                   1329:        printf("%s%d: %s, size = %d sectors\n",
                   1330:                kdbdriver.ud_dname, ui->ui_unit,
                   1331:                kdbtypes[type].ut_name, ra_dsize[ui->ui_unit]);
                   1332:        return (MSCP_DONE);
                   1333: }
                   1334: 
                   1335: /*
                   1336:  * We got some (configured) unit's status.  Return DONE if it succeeded.
                   1337:  */
                   1338: kdbgotstatus(ui, mp)
                   1339:        register struct uba_device *ui;
                   1340:        register struct mscp *mp;
                   1341: {
                   1342: 
                   1343:        if ((mp->mscp_status & M_ST_MASK) != M_ST_SUCCESS) {
                   1344:                printf("kdb%d: attempt to get status for %s%d failed:",
                   1345:                        ui->ui_ctlr, kdbdriver.ud_dname, ui->ui_unit);
                   1346:                mscp_printevent(mp);
                   1347:                return (MSCP_FAILED);
                   1348:        }
                   1349:        /* need to record later for bad block forwarding - for now, print */
                   1350:        printf("\
                   1351: %s%d: unit %d, nspt %d, group %d, ngpc %d, rctsize %d, nrpt %d, nrct %d\n",
                   1352:                kdbdriver.ud_dname, ui->ui_unit, mp->mscp_unit,
                   1353:                mp->mscp_guse.guse_nspt, mp->mscp_guse.guse_group,
                   1354:                mp->mscp_guse.guse_ngpc, mp->mscp_guse.guse_rctsize,
                   1355:                mp->mscp_guse.guse_nrpt, mp->mscp_guse.guse_nrct);
                   1356:        return (MSCP_DONE);
                   1357: }
                   1358: 
                   1359: /*
                   1360:  * A transfer failed.  We get a chance to fix or restart it.
                   1361:  * Need to write the bad block forwaring code first....
                   1362:  */
                   1363: /*ARGSUSED*/
                   1364: kdbioerror(ui, mp, bp)
                   1365:        register struct uba_device *ui;
                   1366:        register struct mscp *mp;
                   1367:        struct buf *bp;
                   1368: {
                   1369: 
                   1370:        if (mp->mscp_flags & M_EF_BBLKR) {
                   1371:                /*
                   1372:                 * A bad block report.  Eventually we will
                   1373:                 * restart this transfer, but for now, just
                   1374:                 * log it and give up.
                   1375:                 */
                   1376:                log(LOG_ERR, "%s%d: bad block report: %d%s\n",
                   1377:                        kdbdriver.ud_dname, ui->ui_unit, mp->mscp_seq.seq_lbn,
                   1378:                        mp->mscp_flags & M_EF_BBLKU ? " + others" : "");
                   1379:        } else {
                   1380:                /*
                   1381:                 * What the heck IS a `serious exception' anyway?
                   1382:                 */
                   1383:                if (mp->mscp_flags & M_EF_SEREX)
                   1384:                        log(LOG_ERR, "%s%d: serious exception reported\n",
                   1385:                                kdbdriver.ud_dname, ui->ui_unit);
                   1386:        }
                   1387:        return (MSCP_FAILED);
                   1388: }
                   1389: 
                   1390: 
                   1391: #ifdef notyet
                   1392: /*
                   1393:  * I/O controls.  Not yet!
                   1394:  */
                   1395: kdbioctl(dev, cmd, flag, data)
                   1396:        dev_t dev;
                   1397:        int cmd, flag;
                   1398:        caddr_t data;
                   1399: {
                   1400:        int error = 0;
                   1401:        register int unit = kdbunit(dev);
                   1402: 
                   1403:        if (unit >= NKRA || uddinfo[unit] == NULL)
                   1404:                return (ENXIO);
                   1405: 
                   1406:        switch (cmd) {
                   1407: 
                   1408:        case KDBIOCREPLACE:
                   1409:                /*
                   1410:                 * Initiate bad block replacement for the given LBN.
                   1411:                 * (Should we allow modifiers?)
                   1412:                 */
                   1413:                error = EOPNOTSUPP;
                   1414:                break;
                   1415: 
                   1416:        case KDBIOCGMICRO:
                   1417:                /*
                   1418:                 * Return the microcode revision for the KDB50 running
                   1419:                 * this drive.
                   1420:                 */
                   1421:                *(int *)data = kdbinfo[kdbdinfo[unit]->ui_ctlr].ki_micro;
                   1422:                break;
                   1423: 
                   1424:        case KDBIOCGSIZE:
                   1425:                /*
                   1426:                 * Return the size (in 512 byte blocks) of this
                   1427:                 * disk drive.
                   1428:                 */
                   1429:                *(daddr_t *)data = ra_dsize[unit];
                   1430:                break;
                   1431: 
                   1432:        default:
                   1433:                error = EINVAL;
                   1434:                break;
                   1435:        }
                   1436:        return (error);
                   1437: }
                   1438: #endif
                   1439: 
                   1440: #ifdef notyet
                   1441: /*
                   1442:  * Reset a KDB50 (self test and all).
                   1443:  * What if it fails?
                   1444:  */
                   1445: kdbreset(ki)
                   1446:        register struct kdbinfo *ki;
                   1447: {
                   1448: 
                   1449:        printf("reset kdb%d", ki->ki_ctlr);
                   1450:        bi_selftest(&ki->ki_kdb.kdb_bi);
                   1451:        ki->ki_state = ST_IDLE;
                   1452:        rminit(ki->ki_map, (long)KI_PTES, (long)1, "kdb", KI_MAPSIZ);
                   1453:        mscp_requeue(&ki->ki_mi);
                   1454:        if (kdbinit(ctlr))
                   1455:                printf(" (hung)");
                   1456:        printf("\n");
                   1457: }
                   1458: #endif
                   1459: 
                   1460: /*
                   1461:  * Watchdog timer:  If the controller is active, and no interrupts
                   1462:  * have occurred for 30 seconds, assume it has gone away.
                   1463:  */
                   1464: kdbwatch()
                   1465: {
                   1466:        register struct kdbinfo *ki;
                   1467:        register int i;
                   1468: 
                   1469:        timeout(kdbwatch, (caddr_t)0, hz);      /* every second */
                   1470:        for (i = 0, ki = kdbinfo; i < NKDB; i++, ki++) {
                   1471:                if ((ki->ki_flags & KDB_ALIVE) == 0)
                   1472:                        continue;
                   1473:                if (ki->ki_state == ST_IDLE)
                   1474:                        continue;
                   1475:                if (ki->ki_state == ST_RUN && !ki->ki_tab.b_active)
                   1476:                        ki->ki_wticks = 0;
                   1477:                else if (++ki->ki_wticks >= 30) {
                   1478:                        ki->ki_wticks = 0;
                   1479:                        printf("kdb%d: lost interrupt\n", i);
                   1480:                        /* kdbreset(ki); */
                   1481:                        panic("kdb lost interrupt");
                   1482:                }
                   1483:        }
                   1484: }
                   1485: 
                   1486: /*
                   1487:  * Do a panic dump.
                   1488:  */
                   1489: #define        DBSIZE  32              /* dump 16K at a time */
                   1490: 
                   1491: struct kdbdumpspace {
                   1492:        struct  kdb1ca kd_ca;
                   1493:        struct  mscp kd_rsp;
                   1494:        struct  mscp kd_cmd;
                   1495: } kdbdumpspace;
                   1496: 
                   1497: kdbdump(dev)
                   1498:        dev_t dev;
                   1499: {
                   1500:        register struct kdbdumpspace *kd;
                   1501:        register struct kdb_regs *k;
                   1502:        register int i;
                   1503:        struct uba_device *ui;
                   1504:        char *start;
                   1505:        int num, blk, unit, maxsz, blkoff;
                   1506: 
                   1507:        /*
                   1508:         * Make sure the device is a reasonable place on which to dump.
                   1509:         */
                   1510:        unit = kdbunit(dev);
                   1511:        if (unit >= NKRA)
                   1512:                return (ENXIO);
                   1513:        ui = PHYS(struct uba_device *, kdbdinfo[unit]);
                   1514:        if (ui == NULL || ui->ui_alive == 0)
                   1515:                return (ENXIO);
                   1516: 
                   1517:        /*
                   1518:         * Find and initialise the KDB; get the physical address of the
                   1519:         * device registers, and of communications area and command and
                   1520:         * response packet.
                   1521:         */
                   1522:        k = PHYS(struct kdbinfo *, &kdbinfo[ui->ui_ctlr])->ki_physkdb;
                   1523:        kd = PHYS(struct kdbdumpspace *, &kdbdumpspace);
                   1524: 
                   1525:        /*
                   1526:         * Initialise the controller, with one command and one response
                   1527:         * packet.
                   1528:         */
                   1529:        bi_reset(&k->kdb_bi);
                   1530:        if (kdbdumpwait(k, KDB_STEP1))
                   1531:                return (EFAULT);
                   1532:        k->kdb_sw = KDB_ERR;
                   1533:        if (kdbdumpwait(k, KDB_STEP2))
                   1534:                return (EFAULT);
                   1535:        k->kdb_sw = (int)&kd->kd_ca.ca_rspdsc;
                   1536:        if (kdbdumpwait(k, KDB_STEP3))
                   1537:                return (EFAULT);
                   1538:        k->kdb_sw = ((int)&kd->kd_ca.ca_rspdsc) >> 16;
                   1539:        if (kdbdumpwait(k, KDB_STEP4))
                   1540:                return (EFAULT);
                   1541:        k->kdb_sw = KDB_GO;
                   1542: 
                   1543:        /*
                   1544:         * Set up the command and response descriptor, then set the
                   1545:         * controller characteristics and bring the drive on line.
                   1546:         * Note that all uninitialised locations in kd_cmd are zero.
                   1547:         */
                   1548:        kd->kd_ca.ca_rspdsc = (long)&kd->kd_rsp.mscp_cmdref;
                   1549:        kd->kd_ca.ca_cmddsc = (long)&kd->kd_cmd.mscp_cmdref;
                   1550:        /* kd->kd_cmd.mscp_sccc.sccc_ctlrflags = 0; */
                   1551:        /* kd->kd_cmd.mscp_sccc.sccc_version = 0; */
                   1552:        if (kdbdumpcmd(M_OP_SETCTLRC, k, kd, ui->ui_ctlr))
                   1553:                return (EFAULT);
                   1554:        kd->kd_cmd.mscp_unit = ui->ui_slave;
                   1555:        if (kdbdumpcmd(M_OP_ONLINE, k, kd, ui->ui_ctlr))
                   1556:                return (EFAULT);
                   1557: 
                   1558:        /*
                   1559:         * Pick up the drive type from the on line end packet;
                   1560:         * convert that to a dump area size and a disk offset.
                   1561:         * Note that the assembler uses pc-relative addressing
                   1562:         * to get at kdbtypes[], no need for PHYS().
                   1563:         */
                   1564:        i = kd->kd_rsp.mscp_onle.onle_drivetype;
                   1565:        if (i >= NTYPES || kdbtypes[i].ut_name == 0) {
                   1566:                printf("disk type %d unknown\ndump ");
                   1567:                return (EINVAL);
                   1568:        }
                   1569:        printf("on %s ", kdbtypes[i].ut_name);
                   1570: 
                   1571:        maxsz = kdbtypes[i].ut_sizes[kdbpart(dev)].nblocks;
                   1572:        blkoff = kdbtypes[i].ut_sizes[kdbpart(dev)].blkoff;
                   1573: 
                   1574:        /*
                   1575:         * Dump all of physical memory, or as much as will fit in the
                   1576:         * space provided.
                   1577:         */
                   1578:        start = 0;
                   1579:        num = maxfree;
                   1580:        if (dumplo < 0)
                   1581:                return (EINVAL);
                   1582:        if (dumplo + num >= maxsz)
                   1583:                num = maxsz - dumplo;
                   1584:        blkoff += dumplo;
                   1585: 
                   1586:        /*
                   1587:         * Write out memory, DBSIZE pages at a time.
                   1588:         * N.B.: this code depends on the fact that the sector
                   1589:         * size == the page size.
                   1590:         */
                   1591:        while (num > 0) {
                   1592:                blk = num > DBSIZE ? DBSIZE : num;
                   1593:                kd->kd_cmd.mscp_unit = ui->ui_slave;
                   1594:                kd->kd_cmd.mscp_seq.seq_lbn = btop(start) + blkoff;
                   1595:                kd->kd_cmd.mscp_seq.seq_bytecount = blk << PGSHIFT;
                   1596:                kd->kd_cmd.mscp_seq.seq_buffer = (long)start | KDB_PHYS;
                   1597:                if (kdbdumpcmd(M_OP_WRITE, k, kd, ui->ui_ctlr))
                   1598:                        return (EIO);
                   1599:                start += blk << PGSHIFT;
                   1600:                num -= blk;
                   1601:        }
                   1602:        return (0);             /* made it! */
                   1603: }
                   1604: 
                   1605: /*
                   1606:  * Wait for some of the bits in `bits' to come on.  If the error bit
                   1607:  * comes on, or ten seconds pass without response, return true (error).
                   1608:  */
                   1609: kdbdumpwait(k, bits)
                   1610:        register struct kdb_regs *k;
                   1611:        register int bits;
                   1612: {
                   1613:        register int timo = todr() + 1000;
                   1614: 
                   1615:        while ((k->kdb_sa & bits) == 0) {
                   1616:                if (k->kdb_sa & KDB_ERR) {
                   1617:                        printf("kdb_sa=%b\ndump ", k->kdb_sa, kdbsr_bits);
                   1618:                        return (1);
                   1619:                }
                   1620:                if (todr() >= timo) {
                   1621:                        printf("timeout\ndump ");
                   1622:                        return (1);
                   1623:                }
                   1624:        }
                   1625:        return (0);
                   1626: }
                   1627: 
                   1628: /*
                   1629:  * Feed a command to the KDB50, wait for its response, and return
                   1630:  * true iff something went wrong.
                   1631:  */
                   1632: kdbdumpcmd(op, k, kd, ctlr)
                   1633:        int op;
                   1634:        register struct kdb_regs *k;
                   1635:        register struct kdbdumpspace *kd;
                   1636:        int ctlr;
                   1637: {
                   1638:        register int n;
                   1639: #define mp (&kd->kd_rsp)
                   1640: 
                   1641:        kd->kd_cmd.mscp_opcode = op;
                   1642:        kd->kd_cmd.mscp_msglen = MSCP_MSGLEN;
                   1643:        kd->kd_rsp.mscp_msglen = MSCP_MSGLEN;
                   1644:        kd->kd_ca.ca_rspdsc |= MSCP_OWN | MSCP_INT;
                   1645:        kd->kd_ca.ca_cmddsc |= MSCP_OWN | MSCP_INT;
                   1646:        if (k->kdb_sa & KDB_ERR) {
                   1647:                printf("kdb_sa=%b\ndump ", k->kdb_sa, kdbsr_bits);
                   1648:                return (1);
                   1649:        }
                   1650:        n = k->kdb_ip;
                   1651:        n = todr() + 1000;
                   1652:        for (;;) {
                   1653:                if (todr() > n) {
                   1654:                        printf("timeout\ndump ");
                   1655:                        return (1);
                   1656:                }
                   1657:                if (kd->kd_ca.ca_cmdint)
                   1658:                        kd->kd_ca.ca_cmdint = 0;
                   1659:                if (kd->kd_ca.ca_rspint == 0)
                   1660:                        continue;
                   1661:                kd->kd_ca.ca_rspint = 0;
                   1662:                if (mp->mscp_opcode == (op | M_OP_END))
                   1663:                        break;
                   1664:                printf("\n");
                   1665:                switch (MSCP_MSGTYPE(mp->mscp_msgtc)) {
                   1666: 
                   1667:                case MSCPT_SEQ:
                   1668:                        printf("sequential");
                   1669:                        break;
                   1670: 
                   1671:                case MSCPT_DATAGRAM:
                   1672:                        mscp_decodeerror("kdb", ctlr, mp);
                   1673:                        printf("datagram");
                   1674:                        break;
                   1675: 
                   1676:                case MSCPT_CREDITS:
                   1677:                        printf("credits");
                   1678:                        break;
                   1679: 
                   1680:                case MSCPT_MAINTENANCE:
                   1681:                        printf("maintenance");
                   1682:                        break;
                   1683: 
                   1684:                default:
                   1685:                        printf("unknown (type 0x%x)",
                   1686:                                MSCP_MSGTYPE(mp->mscp_msgtc));
                   1687:                        break;
                   1688:                }
                   1689:                printf(" ignored\ndump ");
                   1690:                kd->kd_ca.ca_rspdsc |= MSCP_OWN | MSCP_INT;
                   1691:        }
                   1692:        if ((mp->mscp_status & M_ST_MASK) != M_ST_SUCCESS) {
                   1693:                printf("error: op 0x%x => 0x%x status 0x%x\ndump ", op,
                   1694:                        mp->mscp_opcode, mp->mscp_status);
                   1695:                return (1);
                   1696:        }
                   1697:        return (0);
                   1698: #undef mp
                   1699: }
                   1700: 
                   1701: /*
                   1702:  * Return the size of a partition, if known, or -1 if not.
                   1703:  */
                   1704: kdbsize(dev)
                   1705:        dev_t dev;
                   1706: {
                   1707:        register int unit = kdbunit(dev);
                   1708:        register struct uba_device *ui;
                   1709:        register struct size *st;
                   1710: 
                   1711:        if (unit >= NKRA || (ui = kdbdinfo[unit]) == NULL || ui->ui_alive == 0)
                   1712:                return (-1);
                   1713:        st = &kdbtypes[ui->ui_type].ut_sizes[kdbpart(dev)];
                   1714:        if (st->nblocks == -1) {
                   1715:                int s = spl5();
                   1716: 
                   1717:                /*
                   1718:                 * We need to have the drive on line to find the size
                   1719:                 * of this particular partition.
                   1720:                 * IS IT OKAY TO GO TO SLEEP IN THIS ROUTINE?
                   1721:                 * (If not, better not page on one of these...)
                   1722:                 */
                   1723:                if ((ui->ui_flags & UNIT_ONLINE) == 0) {
                   1724:                        if (kdb_bringonline(ui, 0)) {
                   1725:                                splx(s);
                   1726:                                return (-1);
                   1727:                        }
                   1728:                }
                   1729:                splx(s);
                   1730:                if (st->blkoff > ra_dsize[unit])
                   1731:                        return (-1);
                   1732:                return (ra_dsize[unit] - st->blkoff);
                   1733:        }
                   1734:        return (st->nblocks);
                   1735: }
                   1736: 
                   1737: #endif NKDB > 0

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.