summaryrefslogtreecommitdiff
path: root/sys/scsi
diff options
context:
space:
mode:
Diffstat (limited to 'sys/scsi')
-rw-r--r--sys/scsi/scsi_base.c74
-rw-r--r--sys/scsi/sd.c12
2 files changed, 79 insertions, 7 deletions
diff --git a/sys/scsi/scsi_base.c b/sys/scsi/scsi_base.c
index 97b74b62c0e..70fbf7b546d 100644
--- a/sys/scsi/scsi_base.c
+++ b/sys/scsi/scsi_base.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: scsi_base.c,v 1.145 2009/12/01 01:50:35 dlg Exp $ */
+/* $OpenBSD: scsi_base.c,v 1.146 2009/12/07 00:09:27 krw Exp $ */
/* $NetBSD: scsi_base.c,v 1.43 1997/04/02 02:29:36 mycroft Exp $ */
/*
@@ -716,6 +716,14 @@ scsi_xs_exec(struct scsi_xfer *xs)
xs->resid = xs->datalen;
xs->status = 0;
+#ifdef SCSIDEBUG
+ if (xs->sc_link->flags & SDEV_DB1) {
+ show_scsi_xs(xs);
+ if (xs->datalen && (xs->flags & SCSI_DATA_OUT))
+ show_mem(xs->data, min(64, xs->datalen));
+ }
+#endif /* SCSIDEBUG */
+
/*
* scsi_xs_exec() guarantees that scsi_done() will be called on the xs
* it was given. The adapter is responsible for calling scsi_done()
@@ -750,6 +758,15 @@ scsi_done(struct scsi_xfer *xs)
xs->flags |= ITSDONE;
+#ifdef SCSIDEBUG
+ if (xs->sc_link->flags & SDEV_DB1) {
+ if (xs->datalen && (xs->flags & SCSI_DATA_IN))
+ show_mem(xs->data, min(64, xs->datalen));
+ if (xs->status == XS_SENSE || xs->status == XS_SHORTSENSE)
+ show_mem((u_char *)&xs->sense, sizeof(xs->sense));
+ }
+#endif /* SCSIDEBUG */
+
xs->done(xs);
}
@@ -1852,3 +1869,58 @@ scsi_decode_sense(struct scsi_sense_data *sense, int flag)
return (rqsbuf);
}
+
+#ifdef SCSIDEBUG
+/*
+ * Given a scsi_xfer, dump the request, in all its glory
+ */
+void
+show_scsi_xs(struct scsi_xfer *xs)
+{
+ u_char *b = (u_char *)xs->cmd;
+ int i = 0;
+
+ sc_print_addr(xs->sc_link);
+
+ printf("xs(%p): ", xs);
+
+ printf("flg(0x%x)", xs->flags);
+ printf("sc_link(%p)", xs->sc_link);
+ printf("retr(0x%x)", xs->retries);
+ printf("timo(0x%x)", xs->timeout);
+ printf("cmd(%p)", xs->cmd);
+ printf("len(0x%x)", xs->cmdlen);
+ printf("data(%p)", xs->data);
+ printf("len(0x%x)", xs->datalen);
+ printf("res(0x%x)", xs->resid);
+ printf("err(0x%x)", xs->error);
+ printf("bp(%p)\n", xs->bp);
+
+ printf("command: ");
+
+ if ((xs->flags & SCSI_RESET) == 0) {
+ while (i < xs->cmdlen) {
+ if (i)
+ printf(",");
+ printf("%x", b[i++]);
+ }
+ printf("-[%d bytes]\n", xs->datalen);
+ } else
+ printf("-RESET-\n");
+}
+
+void
+show_mem(u_char *address, int num)
+{
+ int x;
+
+ printf("------------------------------");
+ for (x = 0; x < num; x++) {
+ if ((x % 16) == 0)
+ printf("\n%03d: ", x);
+ printf("%02x ", *address++);
+ }
+ printf("\n------------------------------\n");
+}
+#endif /* SCSIDEBUG */
+
diff --git a/sys/scsi/sd.c b/sys/scsi/sd.c
index f532a6cf945..824729f8cb2 100644
--- a/sys/scsi/sd.c
+++ b/sys/scsi/sd.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: sd.c,v 1.172 2009/12/06 17:24:28 krw Exp $ */
+/* $OpenBSD: sd.c,v 1.173 2009/12/07 00:09:27 krw Exp $ */
/* $NetBSD: sd.c,v 1.111 1997/04/02 02:29:41 mycroft Exp $ */
/*-
@@ -691,7 +691,7 @@ sdstart(void *v)
if (sc->flags & SDF_DYING)
return;
- SC_DEBUG(sc_link, SDEV_DB2, ("sdstart\n"));
+ SC_DEBUG(link, SDEV_DB2, ("sdstart\n"));
mtx_enter(&sc->sc_start_mtx);
if (ISSET(sc->flags, SDF_STARTING)) {
@@ -1492,7 +1492,7 @@ sd_flush(struct sd_softc *sc, int flags)
xs = scsi_xs_get(link, flags);
if (xs == NULL) {
- SC_DEBUG(sc_link, SDEV_DB1, ("cache sync failed to get xs\n"));
+ SC_DEBUG(link, SDEV_DB1, ("cache sync failed to get xs\n"));
return;
}
@@ -1512,10 +1512,10 @@ sd_flush(struct sd_softc *sc, int flags)
}
} while (xs->status == XS_NO_CCB);
- if (xs->error != XS_NOERROR)
- SC_DEBUG(sc_link, SDEV_DB1, ("cache sync failed\n"));
- else
+ if (xs->error == XS_NOERROR)
sc->flags &= ~SDF_DIRTY;
+ else
+ SC_DEBUG(link, SDEV_DB1, ("cache sync failed\n"));
scsi_xs_put(xs);
}