diff options
author | Miod Vallat <miod@cvs.openbsd.org> | 2004-05-20 16:42:55 +0000 |
---|---|---|
committer | Miod Vallat <miod@cvs.openbsd.org> | 2004-05-20 16:42:55 +0000 |
commit | e5bc5cc92ea719bf878dbde3c46db4e48fae425e (patch) | |
tree | 8d277d3cd590b53a9ecfb49f8dcadfefd8f5d524 | |
parent | c41ffbca2f28ed5b7b149ac4cf7de4e41ce06512 (diff) |
General cleanup before attempting to move towards bus_space and bus_dma.
Also fix an arithmetic bug which caused almost no harm by luck.
-rw-r--r-- | sys/arch/mvme88k/dev/vs.c | 150 | ||||
-rw-r--r-- | sys/arch/mvme88k/dev/vsreg.h | 24 | ||||
-rw-r--r-- | sys/arch/mvme88k/dev/vsvar.h | 32 |
3 files changed, 11 insertions, 195 deletions
diff --git a/sys/arch/mvme88k/dev/vs.c b/sys/arch/mvme88k/dev/vs.c index cc4f9a9c6aa..cdf86e3eed0 100644 --- a/sys/arch/mvme88k/dev/vs.c +++ b/sys/arch/mvme88k/dev/vs.c @@ -1,4 +1,4 @@ -/* $OpenBSD: vs.c,v 1.34 2004/05/09 05:34:00 krw Exp $ */ +/* $OpenBSD: vs.c,v 1.35 2004/05/20 16:42:54 miod Exp $ */ /* * Copyright (c) 1999 Steve Murphree, Jr. @@ -134,7 +134,6 @@ vsattach(parent, self, args) { struct vs_softc *sc = (struct vs_softc *)self; struct confargs *ca = args; - struct vsreg *rp; int evec; int tmp; bus_space_tag_t iot = ca->ca_iot; @@ -157,7 +156,7 @@ vsattach(parent, self, args) printf(" vec 0x%x", evec); - sc->sc_vsreg = rp = (void *)bus_space_vaddr(iot, ioh); + sc->sc_vsreg = (void *)bus_space_vaddr(iot, ioh); sc->sc_ipl = ca->ca_ipl; sc->sc_nvec = ca->ca_vec; @@ -211,9 +210,6 @@ do_vspoll(sc, to, canreset) /*spl0();*/ while (!(CRSW & (M_CRSW_CRBV | M_CRSW_CC))) { if (--i <= 0) { -#ifdef SDEBUG2 - printf ("waiting: timeout %d crsw 0x%x\n", to, CRSW); -#endif i = 50000; --to; if (to <= 0) { @@ -308,8 +304,7 @@ vs_scsicmd(xs) struct scsi_link *slp = xs->sc_link; struct vs_softc *sc = slp->adapter_softc; int flags; - unsigned long buf, len; - u_short iopb_len; + unsigned int iopb_len; M328_CQE *mc = (M328_CQE*)&sc->sc_vsreg->sh_MCE; M328_CRB *crb = (M328_CRB *)&sc->sc_vsreg->sh_CRB; M328_IOPB *miopb = (M328_IOPB *)&sc->sc_vsreg->sh_MCE_IOPB; @@ -319,51 +314,17 @@ vs_scsicmd(xs) flags = xs->flags; -#ifdef SDEBUG - printf("scsi_cmd() "); - if (xs->cmd->opcode == 0) { - printf("TEST_UNIT_READY "); - } else if (xs->cmd->opcode == REQUEST_SENSE) { - printf("REQUEST_SENSE "); - } else if (xs->cmd->opcode == INQUIRY) { - printf("INQUIRY "); - } else if (xs->cmd->opcode == MODE_SELECT) { - printf("MODE_SELECT "); - } else if (xs->cmd->opcode == MODE_SENSE) { - printf("MODE_SENSE "); - } else if (xs->cmd->opcode == START_STOP) { - printf("START_STOP "); - } else if (xs->cmd->opcode == RESERVE) { - printf("RESERVE "); - } else if (xs->cmd->opcode == RELEASE) { - printf("RELEASE "); - } else if (xs->cmd->opcode == PREVENT_ALLOW) { - printf("PREVENT_ALLOW "); - } else if (xs->cmd->opcode == POSITION_TO_ELEMENT) { - printf("POSITION_TO_EL "); - } else if (xs->cmd->opcode == CHANGE_DEFINITION) { - printf("CHANGE_DEF "); - } else if (xs->cmd->opcode == MODE_SENSE_BIG) { - printf("MODE_SENSE_BIG "); - } else if (xs->cmd->opcode == MODE_SELECT_BIG) { - printf("MODE_SELECT_BIG "); - } else if (xs->cmd->opcode == 0x25) { - printf("READ_CAPACITY "); - } else if (xs->cmd->opcode == 0x08) { - printf("READ_COMMAND "); - } -#endif if (flags & SCSI_POLL) { cqep = mc; iopb = miopb; } else { cqep = vs_getcqe(sc); + if (cqep == NULL) { + xs->error = XS_DRIVER_STUFFUP; + return (TRY_AGAIN_LATER); + } iopb = vs_getiopb(sc); } - if (cqep == NULL) { - xs->error = XS_DRIVER_STUFFUP; - return (TRY_AGAIN_LATER); - } iopb_len = sizeof(M328_short_IOPB) + xs->cmdlen; d16_bzero(iopb, sizeof(M328_IOPB)); @@ -428,13 +389,6 @@ vs_scsicmd(xs) if (crb->crb_CRSW & M_CRSW_AQ) { cqep->cqe_QECR = M_QECR_AA; } - VL(buf, iopb->iopb_BUFF); - VL(len, iopb->iopb_LENGTH); -#ifdef SDEBUG - printf("tgt %d lun %d buf %x len %d wqn %d ipl %d crsw 0x%x\n", - slp->target, slp->lun, buf, len, cqep->cqe_WORK_QUEUE, - iopb->iopb_LEVEL, crb->crb_CRSW); -#endif cqep->cqe_QECR |= M_QECR_GO; if (flags & SCSI_POLL) { @@ -493,9 +447,6 @@ vs_chksense(xs) } */ xs->status = riopb->iopb_STATUS >> 8; -#ifdef SDEBUG - scsi_print_sense(xs); -#endif splx(s); } @@ -525,12 +476,11 @@ vs_getiopb(sc) int slot; if (mcsb->mcsb_QHDP == 0) { - slot = NUM_CQE; + slot = NUM_CQE - 1; } else { slot = mcsb->mcsb_QHDP - 1; } iopb = (M328_IOPB *)&sc->sc_vsreg->sh_IOPB[slot]; - d16_bzero(iopb, sizeof(M328_IOPB)); return iopb; } @@ -551,7 +501,6 @@ vs_initialize(sc) CRB_CLR_DONE(CRSW); d16_bzero(cib, sizeof(M328_CIB)); mcsb->mcsb_QHDP = 0; - sc->sc_qhp = 0; cib->cib_NCQE = 10; cib->cib_BURST = 0; cib->cib_NVECT = sc->sc_ipl << 8; @@ -651,7 +600,6 @@ vs_resync(sc) struct vs_softc *sc; { M328_CQE *mc = (M328_CQE*)&sc->sc_vsreg->sh_MCE; - M328_IOPB *riopb = (M328_IOPB *)&sc->sc_vsreg->sh_RET_IOPB; M328_DRCF *devreset = (M328_DRCF *)&sc->sc_vsreg->sh_MCE_IOPB; u_short i; for (i=0; i<7; i++) { @@ -670,14 +618,6 @@ vs_resync(sc) mc->cqe_QECR = M_QECR_GO; /* poll for the command to complete */ do_vspoll(sc, 0, 0); - if (riopb->iopb_STATUS) { -#ifdef SDEBUG - printf("status: %x\n", riopb->iopb_STATUS); -#endif - sc->sc_tinfo[i].avail = 0; - } else { - sc->sc_tinfo[i].avail = 1; - } if (CRSW & M_CRSW_ER) { CRB_CLR_ER(CRSW); } @@ -754,63 +694,6 @@ vs_checkintr(sc, xs, status) *status = riopb->iopb_STATUS >> 8; error = riopb->iopb_STATUS & 0xFF; -#ifdef SDEBUG - printf("scsi_chk() "); - - if (xs->cmd->opcode == 0) { - printf("TEST_UNIT_READY "); - } else if (xs->cmd->opcode == REQUEST_SENSE) { - printf("REQUEST_SENSE "); - } else if (xs->cmd->opcode == INQUIRY) { - printf("INQUIRY "); - } else if (xs->cmd->opcode == MODE_SELECT) { - printf("MODE_SELECT "); - } else if (xs->cmd->opcode == MODE_SENSE) { - printf("MODE_SENSE "); - } else if (xs->cmd->opcode == START_STOP) { - printf("START_STOP "); - } else if (xs->cmd->opcode == RESERVE) { - printf("RESERVE "); - } else if (xs->cmd->opcode == RELEASE) { - printf("RELEASE "); - } else if (xs->cmd->opcode == PREVENT_ALLOW) { - printf("PREVENT_ALLOW "); - } else if (xs->cmd->opcode == POSITION_TO_ELEMENT) { - printf("POSITION_TO_EL "); - } else if (xs->cmd->opcode == CHANGE_DEFINITION) { - printf("CHANGE_DEF "); - } else if (xs->cmd->opcode == MODE_SENSE_BIG) { - printf("MODE_SENSE_BIG "); - } else if (xs->cmd->opcode == MODE_SELECT_BIG) { - printf("MODE_SELECT_BIG "); - } else if (xs->cmd->opcode == 0x25) { - printf("READ_CAPACITY "); - } else if (xs->cmd->opcode == 0x08) { - printf("READ_COMMAND "); - } - - printf("tgt %d lun %d buf %x len %d status %x ", target, lun, buf, len, riopb->iopb_STATUS); - - if (CRSW & M_CRSW_EX) { - printf("[ex]"); - } - if (CRSW & M_CRSW_QMS) { - printf("[qms]"); - } - if (CRSW & M_CRSW_SC) { - printf("[sc]"); - } - if (CRSW & M_CRSW_SE) { - printf("[se]"); - } - if (CRSW & M_CRSW_AQ) { - printf("[aq]"); - } - if (CRSW & M_CRSW_ER) { - printf("[er]"); - } - printf("\n"); -#endif if (len != xs->datalen) { xs->resid = xs->datalen - len; } else { @@ -845,10 +728,6 @@ vs_nintr(vsc) sc->sc_intrcnt_n.ev_count++; VL((unsigned long)m328_cmd, crb->crb_CTAG); -#ifdef SDEBUG - printf("Interrupt!!! "); - printf("m328_cmd == 0x%x\n", m328_cmd); -#endif /* * If this is a controller error, there won't be a m328_cmd * pointer in the CTAG feild. Bad things happen if you try @@ -885,11 +764,6 @@ vs_eintr(vsc) M328_CMD *m328_cmd; struct scsi_xfer *xs; int crsw = crb->cevsb_CRSW; -#ifdef SDEBUG - int type = crb->cevsb_TYPE; - int length = crb->cevsb_IOPB_LENGTH; - int wq = crb->cevsb_WORK_QUEUE; -#endif int ecode = crb->cevsb_ERROR; int status, s; @@ -899,10 +773,6 @@ vs_eintr(vsc) sc->sc_intrcnt_e.ev_count++; VL((unsigned long)m328_cmd, crb->cevsb_CTAG); -#ifdef SDEBUG - printf("Error Interrupt!!! "); - printf("m328_cmd == 0x%x\n", m328_cmd); -#endif xs = m328_cmd->xs; if (crsw & M_CRSW_RST) { @@ -945,10 +815,6 @@ vs_eintr(vsc) Debugger(); #endif } -#ifdef SDEBUG - printf("%s: crsw = 0x%x iopb_type = %d iopb_len = %d wq = %d error = 0x%x\n", - vs_name(sc), crsw, type, length, wq, ecode); -#endif if (CRSW & M_CRSW_ER) CRB_CLR_ER(CRSW); CRB_CLR_DONE(CRSW); diff --git a/sys/arch/mvme88k/dev/vsreg.h b/sys/arch/mvme88k/dev/vsreg.h index b6cf80efd3b..34ecc91495c 100644 --- a/sys/arch/mvme88k/dev/vsreg.h +++ b/sys/arch/mvme88k/dev/vsreg.h @@ -1,4 +1,4 @@ -/* $OpenBSD: vsreg.h,v 1.5 2003/09/29 09:08:19 miod Exp $ */ +/* $OpenBSD: vsreg.h,v 1.6 2004/05/20 16:42:54 miod Exp $ */ /* * Copyright (c) 1999 Steve Murphree, Jr. * Copyright (c) 1990 The Regents of the University of California. @@ -564,22 +564,6 @@ struct vsreg /**************** END Short I/O Format *******************/ /* - * Scatter gather structure - */ - -typedef struct ipsg -{ - volatile u_short sg_count; /* byte/entry count */ - volatile u_short sg_addrhi; /* datablock/entry address high */ - volatile u_short sg_addrlo; /* datablock/entry address low */ - volatile u_short sg_meminfo; /* memory information */ -}IPSG; - -#define MACSI_SG 256 /* number of MACSI scat/gat entries */ -#define S_MACSI_SG (MACSI_SG * sizeof(IPSG)) -#define MACSI_SG_RSIZE 65535 /* max len of each scatter/gather entry */ - -/* * SCSI IOPB definitions */ @@ -672,12 +656,6 @@ typedef struct ipsg #define MACSI_INVALID_TIMEOUT 0x843 /* The SCSI byte to byte timer expired */ /* - * Handy vector macro. - */ - -#define VEC(c, vec) (((c) -> mc_ipl << 8) + (vec)) - -/* * VME addressing modes */ diff --git a/sys/arch/mvme88k/dev/vsvar.h b/sys/arch/mvme88k/dev/vsvar.h index 5b597ace998..efde7d7eb49 100644 --- a/sys/arch/mvme88k/dev/vsvar.h +++ b/sys/arch/mvme88k/dev/vsvar.h @@ -1,4 +1,4 @@ -/* $OpenBSD: vsvar.h,v 1.8 2003/12/26 10:41:43 miod Exp $ */ +/* $OpenBSD: vsvar.h,v 1.9 2004/05/20 16:42:54 miod Exp $ */ /* * Copyright (c) 1999 Steve Murphree, Jr. * Copyright (c) 1990 The Regents of the University of California. @@ -43,7 +43,7 @@ #define DMAMAXIO (MAXPHYS/NBPG+1) #define LO(x) (u_short)((unsigned long)x & 0x0000FFFF) #define HI(x) (u_short)((unsigned long)x >> 16) -#define OFF(x) (u_short)((long)kvtop((vaddr_t)x) - (long)kvtop((vaddr_t)sc->sc_vsreg)) +#define OFF(x) (u_short)((vaddr_t)x - (vaddr_t)sc->sc_vsreg) #define vs_name(sc) (sc)->sc_dev.dv_xname /**************** Scater/Gather Stuff *******************/ @@ -94,19 +94,6 @@ typedef struct { /**************** END Scater/Gather Stuff *******************/ -struct vs_tinfo { - int cmds; /* #commands processed */ - int dconns; /* #disconnects */ - int touts; /* #timeouts */ - int perrs; /* #parity errors */ - int senses; /* #request sense commands sent */ - ushort lubusy; /* What local units/subr. are busy? */ - u_char flags; - u_char period; /* Period suggestion */ - u_char offset; /* Offset suggestion */ - int avail; /* Is there a device there */ -} tinfo_t; - struct vs_softc { struct device sc_dev; struct intrhand sc_ih_e; @@ -117,22 +104,7 @@ struct vs_softc { u_short sc_evec; u_short sc_nvec; struct scsi_link sc_link; /* proto for sub devices */ - u_long sc_chnl; /* channel 0 or 1 for dual bus cards */ - u_long sc_qhp; /* Command queue head pointer */ struct vsreg *sc_vsreg; -#define SSH_NACB 8 - struct vs_tinfo sc_tinfo[SSH_NACB]; - u_char sc_flags; - u_char sc_sien; - u_char sc_dien; - u_char sc_minsync; - struct map *hus_map; - /* one for each target */ - struct syncpar { - u_char state; - u_char sxfer; - u_char sbcl; - } sc_sync[8]; }; /* sync states */ |