diff options
author | Marco Peereboom <marco@cvs.openbsd.org> | 2005-04-17 16:32:44 +0000 |
---|---|---|
committer | Marco Peereboom <marco@cvs.openbsd.org> | 2005-04-17 16:32:44 +0000 |
commit | b8d4f611a46d77ff1d2e46b5a410cb7451ffa150 (patch) | |
tree | 4c5bf4ec46ab243bd2474d5e975de06363a0193a | |
parent | 6b0b18cad7de70d563398d1df15317c3c5f88445 (diff) |
Timeouts are not ran at splhigh anymore so we don't need splimp.
Inspired by beck@, ok mickey@
-rw-r--r-- | sys/dev/ic/ami.c | 19 |
1 files changed, 5 insertions, 14 deletions
diff --git a/sys/dev/ic/ami.c b/sys/dev/ic/ami.c index 20ff61ce2aa..9596c7356d7 100644 --- a/sys/dev/ic/ami.c +++ b/sys/dev/ic/ami.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ami.c,v 1.32 2005/04/04 22:40:31 marco Exp $ */ +/* $OpenBSD: ami.c,v 1.33 2005/04/17 16:32:43 marco Exp $ */ /* * Copyright (c) 2001 Michael Shalayeff @@ -769,7 +769,7 @@ ami_cmd(ccb, flags, wait) { struct ami_softc *sc = ccb->ccb_sc; bus_dmamap_t dmap = ccb->ccb_dmamap; - int error = 0, i, s; + int error = 0, i; if (ccb->ccb_data) { struct ami_iocmd *cmd = ccb->ccb_cmd; @@ -818,7 +818,6 @@ ami_cmd(ccb, flags, wait) bus_dmamap_sync(sc->dmat, sc->sc_cmdmap, 0, sc->sc_cmdmap->dm_mapsize, BUS_DMASYNC_PREWRITE); - s = splimp(); if ((error = ami_start(ccb, wait))) { AMI_DPRINTF(AMI_D_DMA, ("error=%d ", error)); __asm __volatile(".globl _bpamierr\n_bpamierr:"); @@ -830,7 +829,6 @@ ami_cmd(ccb, flags, wait) if ((error = ami_complete(ccb))) ami_put_ccb(ccb); } - splx(s); return (error); } @@ -904,7 +902,7 @@ ami_stimeout(v) struct scsi_xfer *xs = ccb->ccb_xs; struct ami_iocmd *cmd = ccb->ccb_cmd; volatile struct ami_iocmd *mbox = sc->sc_mbox; - ami_lock_t lock, s; + ami_lock_t lock; lock = AMI_LOCK_AMI(sc); switch (ccb->ccb_state) { @@ -938,10 +936,8 @@ ami_stimeout(v) BUS_DMASYNC_POSTWRITE); bus_dmamap_unload(sc->dmat, ccb->ccb_dmamap); } - s = splimp(); TAILQ_REMOVE(&sc->sc_ccbq, ccb, ccb_link); ami_put_ccb(ccb); - splx(s); xs->error = XS_TIMEOUT; xs->flags |= ITSDONE; scsi_done(xs); @@ -998,7 +994,7 @@ ami_done(sc, idx) { struct ami_ccb *ccb = &sc->sc_ccbs[idx - 1]; struct scsi_xfer *xs = ccb->ccb_xs; - ami_lock_t lock, s; + ami_lock_t lock; AMI_DPRINTF(AMI_D_CMD, ("done(%d) ", ccb->ccb_cmd->acc_id)); @@ -1009,7 +1005,6 @@ ami_done(sc, idx) } lock = AMI_LOCK_AMI(sc); - s = splimp(); ccb->ccb_state = AMI_CCB_READY; TAILQ_REMOVE(&sc->sc_ccbq, ccb, ccb_link); @@ -1043,7 +1038,6 @@ ami_done(sc, idx) } ami_put_ccb(ccb); - splx(s); if (xs) { xs->resid = 0; @@ -1051,7 +1045,6 @@ ami_done(sc, idx) AMI_DPRINTF(AMI_D_CMD, ("scsi_done(%d) ", idx)); scsi_done(xs); } - AMI_UNLOCK_AMI(sc, lock); return (0); @@ -1421,7 +1414,7 @@ ami_intr(v) { struct ami_softc *sc = v; struct ami_iocmd mbox; - int i, s, rv = 0; + int i, rv = 0; ami_lock_t lock; if (TAILQ_EMPTY(&sc->sc_ccbq)) @@ -1430,7 +1423,6 @@ ami_intr(v) AMI_DPRINTF(AMI_D_INTR, ("intr ")); lock = AMI_LOCK_AMI(sc); - s = splimp(); /* XXX need to do this to mask timeouts */ while ((sc->sc_done)(sc, &mbox)) { AMI_DPRINTF(AMI_D_CMD, ("got#%d ", mbox.acc_nstat)); for (i = 0; i < mbox.acc_nstat; i++ ) { @@ -1450,7 +1442,6 @@ ami_intr(v) } #endif - splx(s); AMI_UNLOCK_AMI(sc, lock); AMI_DPRINTF(AMI_D_INTR, ("exit ")); return (rv); |