summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKenneth R Westerback <krw@cvs.openbsd.org>2007-10-20 04:01:40 +0000
committerKenneth R Westerback <krw@cvs.openbsd.org>2007-10-20 04:01:40 +0000
commite9305838eaf52a590c3d0b70b2ee331b6069d895 (patch)
tree2f60c2681e42bb4f2d9d3adf5fd2263edfa3eac1
parent079ef7a62f40903d641ad54285c6354970160e5c (diff)
DO NOT access xs after calling scsi_done(xs). It's not there anymore.
Also set ITSDONE (a.k.a. XS_STS_DONE) in correct field - xs->flags (a.k.a. xs->xs_control) and not xs->status (a.k.a. xs->xs_status). 'totally OK' deraadt@ 'yes' beck@
-rw-r--r--sys/dev/usb/usscanner.c18
1 files changed, 11 insertions, 7 deletions
diff --git a/sys/dev/usb/usscanner.c b/sys/dev/usb/usscanner.c
index 6e8e7b934bd..afba064fcd8 100644
--- a/sys/dev/usb/usscanner.c
+++ b/sys/dev/usb/usscanner.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: usscanner.c,v 1.24 2007/10/11 18:33:15 deraadt Exp $ */
+/* $OpenBSD: usscanner.c,v 1.25 2007/10/20 04:01:39 krw Exp $ */
/* $NetBSD: usscanner.c,v 1.6 2001/01/23 14:04:14 augustss Exp $ */
/*
@@ -495,7 +495,7 @@ usscanner_intr_cb(usbd_xfer_handle xfer, usbd_private_handle priv,
sc->sc_state = UAS_IDLE;
- sc->sc_xs->xs_status |= XS_STS_DONE;
+ sc->sc_xs->xs_control |= XS_STS_DONE;
s = splbio();
scsipi_done(sc->sc_xs);
splx(s);
@@ -717,6 +717,7 @@ usscanner_scsipi_cmd(struct scsipi_xfer *xs)
struct scsipi_link *sc_link = xs->sc_link;
struct usscanner_softc *sc = sc_link->adapter_softc;
usbd_status err;
+ int rslt, s;
#ifdef notyet
DPRINTFN(8, ("%s: usscanner_scsi_cmd: %d:%d "
@@ -769,13 +770,16 @@ usscanner_scsipi_cmd(struct scsipi_xfer *xs)
return (SUCCESSFULLY_QUEUED);
-
done:
sc->sc_state = UAS_IDLE;
- xs->xs_status |= XS_STS_DONE;
- scsipi_done(xs);
+ xs->xs_control |= XS_STS_DONE;
if (xs->xs_control & XS_CTL_POLL)
- return (COMPLETE);
+ rslt = COMPLETE;
else
- return (SUCCESSFULLY_QUEUED);
+ rslt = SUCCESSFULLY_QUEUED;
+ s = splbio();
+ scsipi_done(xs);
+ splx(s);
+
+ return (rslt);
}