diff options
author | Miod Vallat <miod@cvs.openbsd.org> | 2004-08-06 18:54:58 +0000 |
---|---|---|
committer | Miod Vallat <miod@cvs.openbsd.org> | 2004-08-06 18:54:58 +0000 |
commit | 39753332005d0e5e01399fd166aa240dc3bd14b5 (patch) | |
tree | 92d906183a66e8e01350d078b560d123446caf93 /sys/arch | |
parent | c1b43a27911f6445ae60c9df4291c33241bb2dab (diff) |
Misc cleaning and KNF in order to sync this to hp300 soon; no functional
change.
Tested by aoyama@
Diffstat (limited to 'sys/arch')
-rw-r--r-- | sys/arch/luna88k/dev/mb89352.c | 261 | ||||
-rw-r--r-- | sys/arch/luna88k/dev/spc.c | 5 |
2 files changed, 105 insertions, 161 deletions
diff --git a/sys/arch/luna88k/dev/mb89352.c b/sys/arch/luna88k/dev/mb89352.c index df64be521d7..955df282cff 100644 --- a/sys/arch/luna88k/dev/mb89352.c +++ b/sys/arch/luna88k/dev/mb89352.c @@ -1,4 +1,4 @@ -/* $OpenBSD: mb89352.c,v 1.2 2004/07/26 16:36:29 miod Exp $ */ +/* $OpenBSD: mb89352.c,v 1.3 2004/08/06 18:54:57 miod Exp $ */ /* $NetBSD: mb89352.c,v 1.5 2000/03/23 07:01:31 thorpej Exp $ */ /* NecBSD: mb89352.c,v 1.4 1998/03/14 07:31:20 kmatsuda Exp */ @@ -80,14 +80,6 @@ * A few customizable items: */ -/* Use doubleword transfers to/from SCSI chip. Note: This requires - * motherboard support. Basicly, some motherboard chipsets are able to - * split a 32 bit I/O operation into two 16 bit I/O operations, - * transparently to the processor. This speeds up some things, notably long - * data transfers. - */ -#define SPC_USE_DWORDS 0 - /* Synchronous data transfers? */ #define SPC_USE_SYNCHRONOUS 0 #define SPC_SYNC_REQ_ACK_OFS 8 @@ -110,13 +102,14 @@ #define SPC_MSGIN_SPIN 1 /* Will spinwait upto ?ms for a new msg byte */ #define SPC_MSGOUT_SPIN 1 -/* Include debug functions? At the end of this file there are a bunch of +/* + * Include debug functions? At the end of this file there are a bunch of * functions that will print out various information regarding queued SCSI * commands, driver state and chip contents. You can call them from the * kernel debugger. If you set SPC_DEBUG to 0 they are not included (the * kernel uses less memory) but you lose the debugging facilities. */ -#define SPC_DEBUG 1 +/* #define SPC_DEBUG */ #define SPC_ABORT_TIMEOUT 2000 /* time to wait for abort */ @@ -126,7 +119,6 @@ * MB89352 SCSI Protocol Controller (SPC) routines. */ -#include <sys/types.h> #include <sys/param.h> #include <sys/systm.h> #include <sys/kernel.h> @@ -147,16 +139,15 @@ #include <luna88k/dev/mb89352reg.h> #include <luna88k/dev/mb89352var.h> - + #ifndef DDB #define Debugger() panic("should call debugger here (mb89352.c)") #endif /* ! DDB */ -#if SPC_DEBUG +#ifdef SPC_DEBUG int spc_debug = 0x00; /* SPC_SHOWSTART|SPC_SHOWMISC|SPC_SHOWTRACE; */ #endif -void spc_minphys (struct buf *); void spc_done (struct spc_softc *, struct spc_acb *); void spc_dequeue (struct spc_softc *, struct spc_acb *); int spc_scsi_cmd (struct scsi_xfer *); @@ -176,7 +167,7 @@ void spc_abort (struct spc_softc *, struct spc_acb *); void spc_msgout (struct spc_softc *); int spc_dataout_pio (struct spc_softc *, u_char *, int); int spc_datain_pio (struct spc_softc *, u_char *, int); -#if SPC_DEBUG +#ifdef SPC_DEBUG void spc_print_acb (struct spc_acb *); void spc_dump_driver (struct spc_softc *); void spc_dump89352 (struct spc_softc *); @@ -192,53 +183,10 @@ struct scsi_device spc_dev = { NULL, /* have no async handler */ NULL, /* Use default 'done' routine */ }; - -/* - * INITIALIZATION ROUTINES (probe, attach ++) - */ /* - * Do the real search-for-device. - * Prerequisite: sc->sc_iobase should be set to the proper value + * INITIALIZATION ROUTINES (probe, attach ++) */ -int -spc_find(iot, ioh, bdid) - bus_space_tag_t iot; - bus_space_handle_t ioh; - int bdid; -{ - long timeout = SPC_ABORT_TIMEOUT; - - SPC_TRACE(("spc: probing for spc-chip\n")); - /* - * Disable interrupts then reset the FUJITSU chip. - */ - bus_space_write_1(iot, ioh, SCTL, SCTL_DISABLE | SCTL_CTRLRST); - bus_space_write_1(iot, ioh, SCMD, 0); - bus_space_write_1(iot, ioh, PCTL, 0); - bus_space_write_1(iot, ioh, TEMP, 0); - bus_space_write_1(iot, ioh, TCH, 0); - bus_space_write_1(iot, ioh, TCM, 0); - bus_space_write_1(iot, ioh, TCL, 0); - bus_space_write_1(iot, ioh, INTS, 0); - bus_space_write_1(iot, ioh, SCTL, SCTL_DISABLE | SCTL_ABRT_ENAB | SCTL_PARITY_ENAB | SCTL_RESEL_ENAB); - bus_space_write_1(iot, ioh, BDID, bdid); - delay(400); - bus_space_write_1(iot, ioh, SCTL, bus_space_read_1(iot, ioh, SCTL) & ~SCTL_DISABLE); - - /* The following detection is derived from spc.c - * (by Takahide Matsutsuka) in FreeBSD/pccard-test. - */ - while (bus_space_read_1(iot, ioh, PSNS) && timeout) - timeout--; - if (!timeout) { - printf("spc: find failed\n"); - return 0; - } - - SPC_START(("SPC found")); - return 1; -} void /* spc_attach(sc) */ @@ -258,7 +206,7 @@ spc_attach(sc, adapter) * the chip's clock input and the size and offset of the sync period * register. * - * For a 20Mhz clock, this gives us 25, or 100nS, or 10MB/s, as a + * For a 20MHz clock, this gives us 25, or 100nS, or 10MB/s, as a * maximum transfer rate, and 112.5, or 450nS, or 2.22MB/s, as a * minimum transfer rate. */ @@ -302,16 +250,19 @@ spc_reset(sc) */ bus_space_write_1(iot, ioh, SCTL, SCTL_DISABLE | SCTL_CTRLRST); bus_space_write_1(iot, ioh, SCMD, 0); + bus_space_write_1(iot, ioh, TMOD, 0); bus_space_write_1(iot, ioh, PCTL, 0); bus_space_write_1(iot, ioh, TEMP, 0); bus_space_write_1(iot, ioh, TCH, 0); bus_space_write_1(iot, ioh, TCM, 0); bus_space_write_1(iot, ioh, TCL, 0); bus_space_write_1(iot, ioh, INTS, 0); - bus_space_write_1(iot, ioh, SCTL, SCTL_DISABLE | SCTL_ABRT_ENAB | SCTL_PARITY_ENAB | SCTL_RESEL_ENAB); + bus_space_write_1(iot, ioh, SCTL, + SCTL_DISABLE | SCTL_ABRT_ENAB | SCTL_PARITY_ENAB | SCTL_RESEL_ENAB); bus_space_write_1(iot, ioh, BDID, sc->sc_initiator); delay(400); - bus_space_write_1(iot, ioh, SCTL, bus_space_read_1(iot, ioh, SCTL) & ~SCTL_DISABLE); + bus_space_write_1(iot, ioh, SCTL, + bus_space_read_1(iot, ioh, SCTL) & ~SCTL_DISABLE); } @@ -368,7 +319,7 @@ spc_init(sc) timeout_del(&acb->xs->stimeout); spc_done(sc, acb); } - while ((acb = sc->nexus_list.tqh_first) != NULL) { + while ((acb = TAILQ_FIRST(&sc->nexus_list)) != NULL) { acb->xs->error = XS_DRIVER_STUFFUP; timeout_del(&acb->xs->stimeout); spc_done(sc, acb); @@ -435,7 +386,7 @@ spc_get_acb(sc, flags) SPC_TRACE(("spc_get_acb ")); s = splbio(); - while ((acb = sc->free_list.tqh_first) == NULL && + while ((acb = TAILQ_FIRST(&sc->free_list)) == NULL && (flags & SCSI_NOSLEEP) == 0) tsleep(&sc->free_list, PRIBIO, "spcacb", 0); if (acb) { @@ -446,7 +397,7 @@ spc_get_acb(sc, flags) splx(s); return acb; } - + /* * DRIVER FUNCTIONS CALLABLE FROM HIGHER LEVEL DRIVERS */ @@ -538,18 +489,6 @@ spc_scsi_cmd(xs) } /* - * Adjust transfer size in buffer structure - */ -void -spc_minphys(bp) - struct buf *bp; -{ - - SPC_TRACE(("spc_minphys ")); - minphys(bp); -} - -/* * Used when interrupt driven I/O isn't allowed, e.g. during boot. */ int @@ -639,7 +578,8 @@ spc_select(sc, acb) #endif bus_space_write_1(iot, ioh, PCTL, 0); - bus_space_write_1(iot, ioh, TEMP, (1 << sc->sc_initiator) | (1 << target)); + bus_space_write_1(iot, ioh, TEMP, + (1 << sc->sc_initiator) | (1 << target)); /* * Setup BSY timeout (selection timeout). * 250ms according to the SCSI specification. @@ -651,9 +591,10 @@ spc_select(sc, acb) * X = 2 + 113 / 256 * ==> tch = 2, tcm = 113 (correct?) */ + /* Time to the information transfer phase start. */ + /* XXX These values should be calculated from sc_freq */ bus_space_write_1(iot, ioh, TCH, 2); bus_space_write_1(iot, ioh, TCM, 113); - /* Time to the information transfer phase start. */ bus_space_write_1(iot, ioh, TCL, 3); bus_space_write_1(iot, ioh, SCMD, SCMD_SELECT); @@ -678,8 +619,8 @@ spc_reselect(sc, message) */ selid = sc->sc_selid & ~(1 << sc->sc_initiator); if (selid & (selid - 1)) { - printf("%s: reselect with invalid selid %02x; sending DEVICE RESET\n", - sc->sc_dev.dv_xname, selid); + printf("%s: reselect with invalid selid %02x; " + "sending DEVICE RESET\n", sc->sc_dev.dv_xname, selid); SPC_BREAK(); goto reset; } @@ -692,16 +633,15 @@ spc_reselect(sc, message) */ target = ffs(selid) - 1; lun = message & 0x07; - for (acb = sc->nexus_list.tqh_first; acb != NULL; - acb = acb->chain.tqe_next) { + TAILQ_FOREACH(acb, &sc->nexus_list, chain) { sc_link = acb->xs->sc_link; if (sc_link->target == target && sc_link->lun == lun) break; } if (acb == NULL) { - printf("%s: reselect from target %d lun %d with no nexus; sending ABORT\n", - sc->sc_dev.dv_xname, target, lun); + printf("%s: reselect from target %d lun %d with no nexus; " + "sending ABORT\n", sc->sc_dev.dv_xname, target, lun); SPC_BREAK(); goto abort; } @@ -739,7 +679,7 @@ abort: /* * Schedule a SCSI operation. This has now been pulled out of the interrupt * handler so that we may call it from spc_scsi_cmd and spc_done. This may - * save us an unecessary interrupt just to get things going. Should only be + * save us an unnecessary interrupt just to get things going. Should only be * called when state == SPC_IDLE and at bio pl. */ void @@ -758,8 +698,7 @@ spc_sched(sc) * Find first acb in ready queue that is for a target/lunit pair that * is not busy. */ - for (acb = sc->ready_list.tqh_first; acb != NULL; - acb = acb->chain.tqe_next) { + TAILQ_FOREACH(acb, &sc->ready_list, chain) { sc_link = acb->xs->sc_link; ti = &sc->sc_tinfo[sc_link->target]; if ((ti->lubusy & (1 << sc_link->lun)) == 0) { @@ -853,9 +792,9 @@ spc_done(sc, acb) break; default: xs->error = XS_DRIVER_STUFFUP; -#if SPC_DEBUG +#ifdef SPC_DEBUG printf("%s: spc_done: bad stat 0x%x\n", - sc->sc_dev.dv_xname, acb->target_stat); + sc->sc_dev.dv_xname, acb->target_stat); #endif break; } @@ -864,7 +803,7 @@ spc_done(sc, acb) xs->flags |= ITSDONE; -#if SPC_DEBUG +#ifdef SPC_DEBUG if ((spc_debug & SPC_SHOWMISC) != 0) { if (xs->resid != 0) printf("resid=%d ", xs->resid); @@ -899,13 +838,12 @@ spc_dequeue(sc, acb) { SPC_TRACE(("spc_dequeue ")); - if (acb->flags & ACB_NEXUS) { + if (acb->flags & ACB_NEXUS) TAILQ_REMOVE(&sc->nexus_list, acb, chain); - } else { + else TAILQ_REMOVE(&sc->ready_list, acb, chain); - } } - + /* * INTERRUPT/PROTOCOL ENGINE */ @@ -1129,7 +1067,8 @@ nextbyte: spc_sched_msgout(sc, SEND_SDTR); } else { sc_print_addr(acb->xs->sc_link); - printf("sync, offset %d, period %dnsec\n", + printf("sync, offset %d, " + "period %dnsec\n", ti->offset, ti->period * 4); } spc_setsync(sc, ti); @@ -1155,8 +1094,8 @@ nextbyte: #endif default: - printf("%s: unrecognized MESSAGE EXTENDED; sending REJECT\n", - sc->sc_dev.dv_xname); + printf("%s: unrecognized MESSAGE EXTENDED; " + "sending REJECT\n", sc->sc_dev.dv_xname); SPC_BREAK(); goto reject; } @@ -1174,8 +1113,8 @@ nextbyte: case SPC_RESELECTED: if (!MSG_ISIDENTIFY(sc->sc_imess[0])) { - printf("%s: reselect without IDENTIFY; sending DEVICE RESET\n", - sc->sc_dev.dv_xname); + printf("%s: reselect without IDENTIFY; " + "sending DEVICE RESET\n", sc->sc_dev.dv_xname); SPC_BREAK(); goto reset; } @@ -1248,7 +1187,8 @@ spc_msgout(sc) * Set ATN. If we're just sending a trivial 1-byte * message, we'll clear ATN later on anyway. */ - bus_space_write_1(iot, ioh, SCMD, SCMD_SET_ATN); /* XXX? */ + bus_space_write_1(iot, ioh, SCMD, + SCMD_SET_ATN); /* XXX? */ } else { /* This is a continuation of the previous message. */ n = sc->sc_omp - sc->sc_omess; @@ -1280,7 +1220,7 @@ nextmsg: SPC_ASSERT(sc->sc_nexus != NULL); ti = &sc->sc_tinfo[sc->sc_nexus->xs->sc_link->target]; sc->sc_omess[4] = MSG_EXTENDED; - sc->sc_omess[3] = 3; + sc->sc_omess[3] = MSG_EXT_SDTR_LEN; sc->sc_omess[2] = MSG_EXT_SDTR; sc->sc_omess[1] = ti->period >> 2; sc->sc_omess[0] = ti->offset; @@ -1293,7 +1233,7 @@ nextmsg: SPC_ASSERT(sc->sc_nexus != NULL); ti = &sc->sc_tinfo[sc->sc_nexus->xs->sc_link->target]; sc->sc_omess[3] = MSG_EXTENDED; - sc->sc_omess[2] = 2; + sc->sc_omess[2] = MSG_EXT_WDTR_LEN; sc->sc_omess[1] = MSG_EXT_WDTR; sc->sc_omess[0] = ti->width; n = 4; @@ -1347,7 +1287,8 @@ nextbyte: #ifdef x68k bus_space_write_1(iot, ioh, SCMD, SCMD_XFR); /* XXX */ #else - bus_space_write_1(iot, ioh, SCMD, SCMD_XFR | SCMD_PROG_XFR | SCMD_ICPT_XFR); + bus_space_write_1(iot, ioh, SCMD, + SCMD_XFR | SCMD_PROG_XFR | SCMD_ICPT_XFR); #endif for (;;) { if ((bus_space_read_1(iot, ioh, SSTS) & SSTS_BUSY) != 0) @@ -1420,8 +1361,9 @@ nextbyte: out: /* Disable REQ/ACK protocol. */ + return; } - + /* * spc_dataout_pio: perform a data transfer using the FIFO datapath in the spc * Precondition: The SCSI bus should be in the DOUT phase, with REQ asserted @@ -1451,7 +1393,8 @@ spc_dataout_pio(sc, p, n) #ifdef x68k bus_space_write_1(iot, ioh, SCMD, SCMD_XFR); /* XXX */ #else - bus_space_write_1(iot, ioh, SCMD, SCMD_XFR | SCMD_PROG_XFR | SCMD_ICPT_XFR); /* XXX */ + bus_space_write_1(iot, ioh, SCMD, + SCMD_XFR | SCMD_PROG_XFR | SCMD_ICPT_XFR); /* XXX */ #endif for (;;) { if ((bus_space_read_1(iot, ioh, SSTS) & SSTS_BUSY) != 0) @@ -1471,7 +1414,8 @@ spc_dataout_pio(sc, p, n) for (;;) { intstat = bus_space_read_1(iot, ioh, INTS); /* Wait till buffer is empty. */ - if ((bus_space_read_1(iot, ioh, SSTS) & SSTS_DREG_EMPTY) != 0) + if ((bus_space_read_1(iot, ioh, SSTS) & + SSTS_DREG_EMPTY) != 0) break; /* Break on interrupt. */ if (intstat != 0) @@ -1485,9 +1429,8 @@ spc_dataout_pio(sc, p, n) n -= xfer; out += xfer; - while (xfer-- > 0) { + while (xfer-- > 0) bus_space_write_1(iot, ioh, DREG, *p++); - } } if (out == 0) { @@ -1500,7 +1443,8 @@ spc_dataout_pio(sc, p, n) /* See the bytes off chip */ for (;;) { /* Wait till buffer is empty. */ - if ((bus_space_read_1(iot, ioh, SSTS) & SSTS_DREG_EMPTY) != 0) + if ((bus_space_read_1(iot, ioh, SSTS) & + SSTS_DREG_EMPTY) != 0) break; intstat = bus_space_read_1(iot, ioh, INTS); /* Break on interrupt. */ @@ -1517,19 +1461,17 @@ phasechange: int amount; amount = ((bus_space_read_1(iot, ioh, TCH) << 16) | - (bus_space_read_1(iot, ioh, TCM) << 8) | - bus_space_read_1(iot, ioh, TCL)); + (bus_space_read_1(iot, ioh, TCM) << 8) | + bus_space_read_1(iot, ioh, TCL)); if (amount > 0) { out -= amount; SPC_MISC(("+%d ", amount)); } } - /* Turn on ENREQINIT again. */ - return out; } - + /* * spc_datain_pio: perform data transfers using the FIFO datapath in the spc * Precondition: The SCSI bus should be in the DIN phase, with REQ asserted @@ -1547,7 +1489,7 @@ spc_datain_pio(sc, p, n) { bus_space_tag_t iot = sc->sc_iot; bus_space_handle_t ioh = sc->sc_ioh; - u_short intstat; + u_int8_t intstat, sstat; int in = 0; #define DINAMOUNT 8 /* Full FIFO */ @@ -1560,7 +1502,8 @@ spc_datain_pio(sc, p, n) #ifdef x68k bus_space_write_1(iot, ioh, SCMD, SCMD_XFR); /* XXX */ #else - bus_space_write_1(iot, ioh, SCMD, SCMD_XFR | SCMD_PROG_XFR); /* XXX */ + bus_space_write_1(iot, ioh, SCMD, + SCMD_XFR | SCMD_PROG_XFR); /* XXX */ #endif for (;;) { if ((bus_space_read_1(iot, ioh, SSTS) & SSTS_BUSY) != 0) @@ -1577,41 +1520,38 @@ spc_datain_pio(sc, p, n) while (n > 0) { int xfer; -#define INTSMASK 0xff /* Wait for fifo half full or phase mismatch */ for (;;) { - intstat = ((bus_space_read_1(iot, ioh, SSTS) << 8) | - bus_space_read_1(iot, ioh, INTS)); - if ((intstat & (INTSMASK | (SSTS_DREG_FULL << 8))) != - 0) - break; - if ((intstat & (SSTS_DREG_EMPTY << 8)) == 0) + intstat = bus_space_read_1(iot, ioh, INTS); + sstat = bus_space_read_1(iot, ioh, SSTS); + if (intstat != 0 || + (sstat & SSTS_DREG_FULL) != 0 || + (sstat & SSTS_DREG_EMPTY) == 0) break; } #if 1 - if ((intstat & INTSMASK) != 0) + if (intstat != 0) goto phasechange; #else - if ((intstat & INTSMASK) != 0 && - (intstat & (SSTS_DREG_EMPTY << 8))) + if (intstat != 0 && + (sstat & SSTS_DREG_EMPTY) != 0) goto phasechange; #endif - if ((intstat & (SSTS_DREG_FULL << 8)) != 0) + if ((sstat & SSTS_DREG_FULL) != 0) xfer = min(DINAMOUNT, n); else - xfer = min(1, n); + xfer = 1; SPC_MISC((">%d ", xfer)); n -= xfer; in += xfer; - while (xfer-- > 0) { + while (xfer-- > 0) *p++ = bus_space_read_1(iot, ioh, DREG); - } - if ((intstat & INTSMASK) != 0) + if (intstat != 0) goto phasechange; } @@ -1624,6 +1564,7 @@ spc_datain_pio(sc, p, n) */ if (in == 0) { for (;;) { + /* XXX needs timeout */ if (bus_space_read_1(iot, ioh, INTS) != 0) break; } @@ -1633,11 +1574,9 @@ spc_datain_pio(sc, p, n) phasechange: /* Stop the FIFO data path. */ - /* Turn on ENREQINIT again. */ - return in; } - + /* * Catch an interrupt from the adaptor */ @@ -1662,7 +1601,8 @@ spc_intr(arg) /* * Disable interrupt. */ - bus_space_write_1(iot, ioh, SCTL, bus_space_read_1(iot, ioh, SCTL) & ~SCTL_INTR_ENAB); + bus_space_write_1(iot, ioh, SCTL, + bus_space_read_1(iot, ioh, SCTL) & ~SCTL_INTR_ENAB); SPC_TRACE(("spc_intr ")); @@ -1690,7 +1630,8 @@ loop: /* * Check for less serious errors. */ - if ((bus_space_read_1(iot, ioh, SERR) & (SERR_SCSI_PAR|SERR_SPC_PAR)) != 0) { + if ((bus_space_read_1(iot, ioh, SERR) & (SERR_SCSI_PAR|SERR_SPC_PAR)) + != 0) { printf("%s: SCSI bus parity error\n", sc->sc_dev.dv_xname); if (sc->sc_prevphase == PH_MSGIN) { sc->sc_flags |= SPC_DROP_MSGIN; @@ -1751,8 +1692,8 @@ loop: * c) Mark device as busy. */ if (sc->sc_state != SPC_SELECTING) { - printf("%s: selection out while idle; resetting\n", - sc->sc_dev.dv_xname); + printf("%s: selection out while idle; " + "resetting\n", sc->sc_dev.dv_xname); SPC_BREAK(); goto reset; } @@ -1788,7 +1729,8 @@ loop: /* On our first connection, schedule a timeout. */ if ((acb->xs->flags & SCSI_POLL) == 0) { - timeout_set(&acb->xs->stimeout, spc_timeout, acb); + timeout_set(&acb->xs->stimeout, spc_timeout, + acb); timeout_add(&acb->xs->stimeout, (acb->timeout * hz) / 1000); } @@ -1797,8 +1739,8 @@ loop: SPC_MISC(("selection timeout ")); if (sc->sc_state != SPC_SELECTING) { - printf("%s: selection timeout while idle; resetting\n", - sc->sc_dev.dv_xname); + printf("%s: selection timeout while idle; " + "resetting\n", sc->sc_dev.dv_xname); SPC_BREAK(); goto reset; } @@ -1811,7 +1753,8 @@ loop: goto finish; } else { if (sc->sc_state != SPC_IDLE) { - printf("%s: BUS FREE while not idle; state=%d\n", + printf("%s: BUS FREE while not idle; " + "state=%d\n", sc->sc_dev.dv_xname, sc->sc_state); SPC_BREAK(); goto out; @@ -1831,12 +1774,11 @@ loop: } if ((ints & INTS_DISCON) != 0) { - /* We've gone to BUS FREE phase. */ + /* disable disconnect interrupt */ bus_space_write_1(iot, ioh, PCTL, bus_space_read_1(iot, ioh, PCTL) & ~PCTL_BFINT_ENAB); - /* disable disconnect interrupt */ + /* XXX reset interrput */ bus_space_write_1(iot, ioh, INTS, ints); - /* XXX reset interrput */ switch (sc->sc_state) { case SPC_RESELECTED: @@ -1881,7 +1823,8 @@ loop: * disconnecting, and this is necessary to * clean up their state. */ - printf("%s: unexpected disconnect; sending REQUEST SENSE\n", + printf("%s: unexpected disconnect; " + "sending REQUEST SENSE\n", sc->sc_dev.dv_xname); SPC_BREAK(); spc_sense(sc, acb); @@ -1905,7 +1848,7 @@ loop: } } else if ((ints & INTS_CMD_DONE) != 0 && - sc->sc_prevphase == PH_MSGIN && sc->sc_state != SPC_CONNECTED) + sc->sc_prevphase == PH_MSGIN && sc->sc_state != SPC_CONNECTED) goto out; dophase: @@ -1925,7 +1868,9 @@ dophase: * State transition. */ sc->sc_phase = bus_space_read_1(iot, ioh, PSNS) & PH_MASK; -/* bus_space_write_1(iot, ioh, PCTL, sc->sc_phase);*/ +#if 0 + bus_space_write_1(iot, ioh, PCTL, sc->sc_phase); +#endif SPC_MISC(("phase=%d\n", sc->sc_phase)); switch (sc->sc_phase) { @@ -1948,12 +1893,12 @@ dophase: case PH_CMD: if (sc->sc_state != SPC_CONNECTED) break; -#if SPC_DEBUG +#ifdef SPC_DEBUG if ((spc_debug & SPC_SHOWMISC) != 0) { SPC_ASSERT(sc->sc_nexus != NULL); acb = sc->sc_nexus; printf("cmd=0x%02x+%d ", - acb->scsi_cmd.opcode, acb->scsi_cmd_length-1); + acb->scsi_cmd.opcode, acb->scsi_cmd_length - 1); } #endif n = spc_dataout_pio(sc, sc->sc_cp, sc->sc_cleft); @@ -2073,7 +2018,7 @@ spc_timeout(arg) splx(s); } - + #ifdef SPC_DEBUG /* * The following functions are mostly used for debugging purposes, either @@ -2118,15 +2063,13 @@ spc_print_active_acb() struct spc_softc *sc = spc_cd.cd_devs[0]; /* XXX */ printf("ready list:\n"); - for (acb = sc->ready_list.tqh_first; acb != NULL; - acb = acb->chain.tqe_next) + TAILQ_FOREACH(acb, &sc->ready_list, chain) spc_print_acb(acb); printf("nexus:\n"); if (sc->sc_nexus != NULL) spc_print_acb(sc->sc_nexus); printf("nexus list:\n"); - for (acb = sc->nexus_list.tqh_first; acb != NULL; - acb = acb->chain.tqe_next) + TAILQ_FOREACH(acb, &sc->nexus_list, chain) spc_print_acb(acb); } @@ -2171,8 +2114,8 @@ spc_dump_driver(sc) int i; printf("nexus=%p prevphase=%x\n", sc->sc_nexus, sc->sc_prevphase); - printf("state=%x msgin=%x msgpriq=%x msgoutq=%x lastmsg=%x currmsg=%x\n", - sc->sc_state, sc->sc_imess[0], + printf("state=%x msgin=%x msgpriq=%x msgoutq=%x lastmsg=%x " + "currmsg=%x\n", sc->sc_state, sc->sc_imess[0], sc->sc_msgpriq, sc->sc_msgoutq, sc->sc_lastmsg, sc->sc_currmsg); for (i = 0; i < 7; i++) { ti = &sc->sc_tinfo[i]; diff --git a/sys/arch/luna88k/dev/spc.c b/sys/arch/luna88k/dev/spc.c index bdd99aeaf71..cb394609ff6 100644 --- a/sys/arch/luna88k/dev/spc.c +++ b/sys/arch/luna88k/dev/spc.c @@ -1,4 +1,4 @@ -/* $OpenBSD: spc.c,v 1.2 2004/07/27 12:36:32 miod Exp $ */ +/* $OpenBSD: spc.c,v 1.3 2004/08/06 18:54:57 miod Exp $ */ /* $NetBSD: spc.c,v 1.4 2003/07/05 19:00:17 tsutsui Exp $ */ /*- @@ -40,6 +40,7 @@ #include <sys/param.h> #include <sys/systm.h> #include <sys/device.h> +#include <sys/buf.h> #include <machine/bus.h> #include <machine/cpu.h> @@ -67,7 +68,7 @@ struct cfdriver spc_cd = { struct scsi_adapter spc_switch = { spc_scsi_cmd, - spc_minphys, /* no max at this level; handled by DMA code */ + minphys, /* no max at this level; handled by DMA code */ NULL, NULL, }; |