From 6f256e16a311079a70cd9106105a42b0871601dd Mon Sep 17 00:00:00 2001 From: Kenneth R Westerback Date: Mon, 5 Nov 2007 20:30:45 +0000 Subject: More scsi_done() at SPLBIO. Wrap another interrupt function call while polling in splbio/splx. Wrap one call to dpt_done_ccb() not already at SPLBIO. --- sys/dev/ic/dpt.c | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) (limited to 'sys/dev') diff --git a/sys/dev/ic/dpt.c b/sys/dev/ic/dpt.c index f1a6c59dd0c..2251e342f2c 100644 --- a/sys/dev/ic/dpt.c +++ b/sys/dev/ic/dpt.c @@ -1,4 +1,4 @@ -/* $OpenBSD: dpt.c,v 1.12 2007/04/10 17:47:55 miod Exp $ */ +/* $OpenBSD: dpt.c,v 1.13 2007/11/05 20:30:44 krw Exp $ */ /* $NetBSD: dpt.c,v 1.12 1999/10/23 16:26:33 ad Exp $ */ /*- @@ -521,7 +521,7 @@ dpt_poll(sc, ccb) struct dpt_softc *sc; struct dpt_ccb *ccb; { - int i; + int i, s; #ifdef DEBUG if ((ccb->ccb_flg & CCB_PRIVATE) == 0) @@ -532,8 +532,11 @@ dpt_poll(sc, ccb) return (0); for (i = ccb->ccb_timeout * 20; i; i--) { - if ((dpt_inb(sc, HA_AUX_STATUS) & HA_AUX_INTR) != 0) + if ((dpt_inb(sc, HA_AUX_STATUS) & HA_AUX_INTR) != 0) { + s = splbio(); dpt_intr(sc); + splx(s); + } if ((ccb->ccb_flg & CCB_INTR) != 0) return (0); DELAY(50); @@ -1232,7 +1235,10 @@ dpt_scsi_cmd(xs) dpt_timeout(ccb); } + s = splbio(); dpt_done_ccb(sc, ccb); + splx(s); + return (COMPLETE); } -- cgit v1.2.3