Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/scsipi Sprinkle some dtrace probes into scsi(4).
details: https://anonhg.NetBSD.org/src/rev/7e20a5979c64
branches: trunk
changeset: 969395:7e20a5979c64
user: riastradh <riastradh%NetBSD.org@localhost>
date: Wed Feb 19 16:05:41 2020 +0000
description:
Sprinkle some dtrace probes into scsi(4).
diffstat:
sys/dev/scsipi/scsi_sdt.h | 36 ++++++++++++++++++++++++
sys/dev/scsipi/scsipi_base.c | 65 ++++++++++++++++++++++++++++++++++++++-----
2 files changed, 93 insertions(+), 8 deletions(-)
diffs (241 lines):
diff -r 2e2c5c5bad0f -r 7e20a5979c64 sys/dev/scsipi/scsi_sdt.h
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/dev/scsipi/scsi_sdt.h Wed Feb 19 16:05:41 2020 +0000
@@ -0,0 +1,36 @@
+/* $NetBSD: scsi_sdt.h,v 1.1 2020/02/19 16:05:41 riastradh Exp $ */
+
+/*-
+ * Copyright (c) 2020 The NetBSD Foundation, Inc.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
+ * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+ * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#ifndef _DEV_SCSIPI_SCSI_SDT_H_
+#define _DEV_SCSIPI_SCSI_SDT_H_
+
+#include <sys/sdt.h>
+
+SDT_PROVIDER_DECLARE(scsi);
+
+#endif /* _DEV_SCSIPI_SCSI_SDT_H_ */
diff -r 2e2c5c5bad0f -r 7e20a5979c64 sys/dev/scsipi/scsipi_base.c
--- a/sys/dev/scsipi/scsipi_base.c Wed Feb 19 16:04:39 2020 +0000
+++ b/sys/dev/scsipi/scsipi_base.c Wed Feb 19 16:05:41 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: scsipi_base.c,v 1.184 2019/11/10 21:16:37 chs Exp $ */
+/* $NetBSD: scsipi_base.c,v 1.185 2020/02/19 16:05:41 riastradh Exp $ */
/*-
* Copyright (c) 1998, 1999, 2000, 2002, 2003, 2004 The NetBSD Foundation, Inc.
@@ -31,7 +31,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: scsipi_base.c,v 1.184 2019/11/10 21:16:37 chs Exp $");
+__KERNEL_RCSID(0, "$NetBSD: scsipi_base.c,v 1.185 2020/02/19 16:05:41 riastradh Exp $");
#ifdef _KERNEL_OPT
#include "opt_scsi.h"
@@ -51,6 +51,7 @@
#include <sys/hash.h>
#include <sys/atomic.h>
+#include <dev/scsipi/scsi_sdt.h>
#include <dev/scsipi/scsi_spc.h>
#include <dev/scsipi/scsipi_all.h>
#include <dev/scsipi/scsipi_disk.h>
@@ -62,6 +63,38 @@
#include <machine/param.h>
+SDT_PROVIDER_DEFINE(scsi);
+
+SDT_PROBE_DEFINE3(scsi, base, tag, get,
+ "struct scsipi_xfer *"/*xs*/, "uint8_t"/*tag*/, "uint8_t"/*type*/);
+SDT_PROBE_DEFINE3(scsi, base, tag, put,
+ "struct scsipi_xfer *"/*xs*/, "uint8_t"/*tag*/, "uint8_t"/*type*/);
+
+SDT_PROBE_DEFINE3(scsi, base, adapter, request__start,
+ "struct scsipi_channel *"/*chan*/,
+ "scsipi_adapter_req_t"/*req*/,
+ "void *"/*arg*/);
+SDT_PROBE_DEFINE3(scsi, base, adapter, request__done,
+ "struct scsipi_channel *"/*chan*/,
+ "scsipi_adapter_req_t"/*req*/,
+ "void *"/*arg*/);
+
+SDT_PROBE_DEFINE1(scsi, base, queue, batch__start,
+ "struct scsipi_channel *"/*chan*/);
+SDT_PROBE_DEFINE2(scsi, base, queue, run,
+ "struct scsipi_channel *"/*chan*/,
+ "struct scsipi_xfer *"/*xs*/);
+SDT_PROBE_DEFINE1(scsi, base, queue, batch__done,
+ "struct scsipi_channel *"/*chan*/);
+
+SDT_PROBE_DEFINE1(scsi, base, xfer, execute, "struct scsipi_xfer *"/*xs*/);
+SDT_PROBE_DEFINE1(scsi, base, xfer, enqueue, "struct scsipi_xfer *"/*xs*/);
+SDT_PROBE_DEFINE1(scsi, base, xfer, done, "struct scsipi_xfer *"/*xs*/);
+SDT_PROBE_DEFINE1(scsi, base, xfer, redone, "struct scsipi_xfer *"/*xs*/);
+SDT_PROBE_DEFINE1(scsi, base, xfer, complete, "struct scsipi_xfer *"/*xs*/);
+SDT_PROBE_DEFINE1(scsi, base, xfer, restart, "struct scsipi_xfer *"/*xs*/);
+SDT_PROBE_DEFINE1(scsi, base, xfer, free, "struct scsipi_xfer *"/*xs*/);
+
static int scsipi_complete(struct scsipi_xfer *);
static void scsipi_request_sense(struct scsipi_xfer *);
static int scsipi_enqueue(struct scsipi_xfer *);
@@ -378,6 +411,8 @@
}
xs->xs_tag_id = tag;
+ SDT_PROBE3(scsi, base, tag, get,
+ xs, xs->xs_tag_id, xs->xs_tag_type);
}
/*
@@ -395,6 +430,9 @@
KASSERT(mutex_owned(chan_mtx(periph->periph_channel)));
+ SDT_PROBE3(scsi, base, tag, put,
+ xs, xs->xs_tag_id, xs->xs_tag_type);
+
word = xs->xs_tag_id >> 5;
bit = xs->xs_tag_id & 0x1f;
@@ -541,6 +579,7 @@
struct scsipi_periph *periph = xs->xs_periph;
int flags = xs->xs_control;
+ SDT_PROBE1(scsi, base, xfer, free, xs);
SC_DEBUG(periph, SCSIPI_DB3, ("scsipi_free_xs\n"));
KASSERT(mutex_owned(chan_mtx(periph->periph_channel)));
@@ -1559,6 +1598,7 @@
#endif
mutex_enter(chan_mtx(chan));
+ SDT_PROBE1(scsi, base, xfer, done, xs);
/*
* The resource this command was using is now free.
*/
@@ -1573,6 +1613,7 @@
* that this won't ever happen (and can be turned into
* a KASSERT().
*/
+ SDT_PROBE1(scsi, base, xfer, redone, xs);
mutex_exit(chan_mtx(chan));
goto out;
}
@@ -1704,6 +1745,8 @@
struct scsipi_channel *chan = periph->periph_channel;
int error;
+ SDT_PROBE1(scsi, base, xfer, complete, xs);
+
#ifdef DIAGNOSTIC
if ((xs->xs_control & XS_CTL_ASYNC) != 0 && xs->bp == NULL)
panic("scsipi_complete: XS_CTL_ASYNC but no buf");
@@ -1872,6 +1915,7 @@
mutex_enter(chan_mtx(chan));
if (error == ERESTART) {
+ SDT_PROBE1(scsi, base, xfer, restart, xs);
/*
* If we get here, the periph has been thawed and frozen
* again if we had to issue recovery commands. Alternatively,
@@ -1981,6 +2025,8 @@
struct scsipi_channel *chan = xs->xs_periph->periph_channel;
struct scsipi_xfer *qxs;
+ SDT_PROBE1(scsi, base, xfer, enqueue, xs);
+
/*
* If the xfer is to be polled, and there are already jobs on
* the queue, we can't proceed.
@@ -2042,6 +2088,7 @@
struct scsipi_xfer *xs;
struct scsipi_periph *periph;
+ SDT_PROBE1(scsi, base, queue, batch__start, chan);
for (;;) {
mutex_enter(chan_mtx(chan));
@@ -2051,7 +2098,7 @@
*/
if (chan->chan_qfreeze != 0) {
mutex_exit(chan_mtx(chan));
- return;
+ break;
}
/*
@@ -2081,7 +2128,7 @@
* Can't find any work to do right now.
*/
mutex_exit(chan_mtx(chan));
- return;
+ break;
got_one:
/*
@@ -2111,7 +2158,7 @@
* XXX: We should be able to note that
* XXX: that resources are needed here!
*/
- return;
+ break;
}
/*
* scsipi_grow_resources() allocated the resource
@@ -2135,11 +2182,10 @@
periph->periph_sent++;
mutex_exit(chan_mtx(chan));
+ SDT_PROBE2(scsi, base, queue, run, chan, xs);
scsipi_adapter_request(chan, ADAPTER_REQ_RUN_XFER, xs);
}
-#ifdef DIAGNOSTIC
- panic("scsipi_run_queue: impossible");
-#endif
+ SDT_PROBE1(scsi, base, queue, batch__done, chan);
}
/*
@@ -2164,6 +2210,7 @@
xs->error = XS_NOERROR;
xs->resid = xs->datalen;
xs->status = SCSI_OK;
+ SDT_PROBE1(scsi, base, xfer, execute, xs);
#ifdef SCSIPI_DEBUG
if (xs->xs_periph->periph_dbflags & SCSIPI_DB3) {
@@ -2783,7 +2830,9 @@
struct scsipi_adapter *adapt = chan->chan_adapter;
scsipi_adapter_lock(adapt);
+ SDT_PROBE3(scsi, base, adapter, request__start, chan, req, arg);
(adapt->adapt_request)(chan, req, arg);
+ SDT_PROBE3(scsi, base, adapter, request__done, chan, req, arg);
scsipi_adapter_unlock(adapt);
}
Home |
Main Index |
Thread Index |
Old Index