diff options
Diffstat (limited to 'sys/dev')
-rw-r--r-- | sys/dev/pci/arc.c | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/sys/dev/pci/arc.c b/sys/dev/pci/arc.c index d8f05d61248..948d7cf1139 100644 --- a/sys/dev/pci/arc.c +++ b/sys/dev/pci/arc.c @@ -1,4 +1,4 @@ -/* $OpenBSD: arc.c,v 1.87 2010/07/01 03:20:38 matthew Exp $ */ +/* $OpenBSD: arc.c,v 1.88 2010/07/02 20:52:14 mk Exp $ */ /* * Copyright (c) 2006 David Gwynne <dlg@openbsd.org> @@ -23,6 +23,7 @@ #include <sys/buf.h> #include <sys/kernel.h> #include <sys/malloc.h> +#include <sys/mutex.h> #include <sys/device.h> #include <sys/rwlock.h> @@ -375,6 +376,7 @@ struct arc_softc { struct arc_dmamem *sc_requests; struct arc_ccb *sc_ccbs; struct arc_ccb_list sc_ccb_free; + struct mutex sc_ccb_mtx; struct scsibus_softc *sc_scsibus; @@ -723,9 +725,7 @@ arc_scsi_cmd(struct scsi_xfer *xs) return; } - s = splbio(); ccb = arc_get_ccb(sc); - splx(s); if (ccb == NULL) { xs->error = XS_DRIVER_STUFFUP; scsi_done(xs); @@ -736,10 +736,8 @@ arc_scsi_cmd(struct scsi_xfer *xs) if (arc_load_xs(ccb) != 0) { xs->error = XS_DRIVER_STUFFUP; - s = splbio(); arc_put_ccb(sc, ccb); scsi_done(xs); - splx(s); return; } @@ -1900,6 +1898,7 @@ arc_alloc_ccbs(struct arc_softc *sc) int i; SLIST_INIT(&sc->sc_ccb_free); + mtx_init(&sc->sc_ccb_mtx, IPL_BIO); sc->sc_ccbs = malloc(sizeof(struct arc_ccb) * sc->sc_req_count, M_DEVBUF, M_WAITOK | M_ZERO); @@ -1951,9 +1950,11 @@ arc_get_ccb(struct arc_softc *sc) { struct arc_ccb *ccb; + mtx_enter(&sc->sc_ccb_mtx); ccb = SLIST_FIRST(&sc->sc_ccb_free); if (ccb != NULL) SLIST_REMOVE_HEAD(&sc->sc_ccb_free, ccb_link); + mtx_leave(&sc->sc_ccb_mtx); return (ccb); } @@ -1963,5 +1964,7 @@ arc_put_ccb(struct arc_softc *sc, struct arc_ccb *ccb) { ccb->ccb_xs = NULL; bzero(ccb->ccb_cmd, ARC_MAX_IOCMDLEN); + mtx_enter(&sc->sc_ccb_mtx); SLIST_INSERT_HEAD(&sc->sc_ccb_free, ccb, ccb_link); + mtx_leave(&sc->sc_ccb_mtx); } |