Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/dev/usb umass dtrace probes



details:   https://anonhg.NetBSD.org/src/rev/872a5fbfdf57
branches:  trunk
changeset: 1007428:872a5fbfdf57
user:      riastradh <riastradh%NetBSD.org@localhost>
date:      Wed Feb 19 16:04:01 2020 +0000

description:
umass dtrace probes

diffstat:

 sys/dev/usb/umass.c |  111 +++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 106 insertions(+), 5 deletions(-)

diffs (truncated from 316 to 300 lines):

diff -r 62ea733e94ee -r 872a5fbfdf57 sys/dev/usb/umass.c
--- a/sys/dev/usb/umass.c       Wed Feb 19 16:03:30 2020 +0000
+++ b/sys/dev/usb/umass.c       Wed Feb 19 16:04:01 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: umass.c,v 1.179 2020/02/19 16:02:50 riastradh Exp $    */
+/*     $NetBSD: umass.c,v 1.180 2020/02/19 16:04:01 riastradh Exp $    */
 
 /*
  * Copyright (c) 2003 The NetBSD Foundation, Inc.
@@ -124,7 +124,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: umass.c,v 1.179 2020/02/19 16:02:50 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: umass.c,v 1.180 2020/02/19 16:04:01 riastradh Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_usb.h"
@@ -144,6 +144,7 @@
 #include <sys/systm.h>
 
 #include <dev/usb/usb.h>
+#include <dev/usb/usb_sdt.h>
 #include <dev/usb/usbdi.h>
 #include <dev/usb/usbdi_util.h>
 #include <dev/usb/usbdevs.h>
@@ -157,6 +158,56 @@
 #include <dev/scsipi/scsipi_all.h>
 #include <dev/scsipi/scsipiconf.h>
 
+SDT_PROBE_DEFINE1(usb, umass, device, attach__start,
+    "struct umass_softc *"/*sc*/);
+SDT_PROBE_DEFINE2(usb, umass, device, attach__done,
+    "struct umass_softc *"/*sc*/, "usbd_status"/*err*/);
+SDT_PROBE_DEFINE1(usb, umass, device, detach__start,
+    "struct umass_softc *"/*sc*/);
+SDT_PROBE_DEFINE2(usb, umass, device, detach__done,
+    "struct umass_softc *"/*sc*/, "int"/*error*/);
+
+SDT_PROBE_DEFINE7(usb, umass, transfer, start__bbb,
+    "struct umass_softc *"/*sc*/,
+    "transfer_cb_f"/*cb*/,
+    "void *"/*priv*/,
+    "void *"/*data*/,
+    "int"/*datalen*/,
+    "int"/*dir*/,
+    "int"/*timeout*/);
+SDT_PROBE_DEFINE7(usb, umass, transfer, start__cbi,
+    "struct umass_softc *"/*sc*/,
+    "transfer_cb_f"/*cb*/,
+    "void *"/*priv*/,
+    "void *"/*data*/,
+    "int"/*datalen*/,
+    "int"/*dir*/,
+    "int"/*timeout*/);
+SDT_PROBE_DEFINE7(usb, umass, transfer, done,
+    "struct umass_softc *"/*sc*/,
+    "transfer_cb_f"/*cb*/,
+    "void *"/*priv*/,
+    "void *"/*data*/,
+    "int"/*datalen*/,
+    "int"/*resid*/,
+    "int"/*status*/);  /* STATUS_* */
+
+SDT_PROBE_DEFINE3(usb, umass, bbb, state,
+    "struct umass_softc *"/*sc*/,
+    "struct usbd_xfer *"/*xfer*/,
+    "usbd_status"/*err*/);
+SDT_PROBE_DEFINE2(usb, umass, bbb, reset,
+    "struct umass_softc *"/*sc*/,
+    "int"/*status*/);
+
+SDT_PROBE_DEFINE3(usb, umass, cbi, state,
+    "struct umass_softc *"/*sc*/,
+    "struct usbd_xfer *"/*xfer*/,
+    "usbd_status"/*err*/);
+SDT_PROBE_DEFINE2(usb, umass, cbi, reset,
+    "struct umass_softc *"/*sc*/,
+    "int"/*status*/);
+
 #ifdef USB_DEBUG
 #ifdef UMASS_DEBUG
 int umassdebug = 0;
@@ -335,6 +386,8 @@
        usbd_status err;
        int i, error;
 
+       SDT_PROBE1(usb, umass, device, attach__start,  sc);
+
        sc->sc_dev = self;
 
        aprint_naive("\n");
@@ -382,6 +435,8 @@
                default:
                        DPRINTFM(UDMASS_GEN, "Unsupported wire protocol %ju",
                            uiaa->uiaa_proto, 0, 0, 0);
+                       SDT_PROBE2(usb, umass, device, attach__done,
+                           sc, USBD_IOERROR);
                        return;
                }
        }
@@ -405,6 +460,8 @@
                default:
                        DPRINTFM(UDMASS_GEN, "Unsupported command protocol %ju",
                            uiaa->uiaa_subclass, 0, 0, 0);
+                       SDT_PROBE2(usb, umass, device, attach__done,
+                           sc, USBD_IOERROR);
                        return;
                }
        }
@@ -451,6 +508,7 @@
                err = (*quirk->uq_init)(sc);
                if (err) {
                        aprint_error_dev(self, "quirk init failed\n");
+                       SDT_PROBE2(usb, umass, device, attach__done,  sc, err);
                        umass_disco(sc);
                        return;
                }
@@ -473,6 +531,8 @@
                if (ed == NULL) {
                        aprint_error_dev(self,
                            "could not read endpoint descriptor\n");
+                       SDT_PROBE2(usb, umass, device, attach__done,
+                           sc, USBD_IOERROR);
                        return;
                }
                if (UE_GET_DIR(ed->bEndpointAddress) == UE_DIR_IN
@@ -515,6 +575,7 @@
                if (err) {
                        aprint_error_dev(self, "unable to get Max Lun: %s\n",
                            usbd_errstr(err));
+                       SDT_PROBE2(usb, umass, device, attach__done,  sc, err);
                        return;
                }
                if (sc->maxlun > 0)
@@ -532,6 +593,7 @@
        if (err) {
                aprint_error_dev(self, "cannot open %u-out pipe (bulk)\n",
                    sc->sc_epaddr[UMASS_BULKOUT]);
+               SDT_PROBE2(usb, umass, device, attach__done,  sc, err);
                umass_disco(sc);
                return;
        }
@@ -543,6 +605,7 @@
        if (err) {
                aprint_error_dev(self, "could not open %u-in pipe (bulk)\n",
                    sc->sc_epaddr[UMASS_BULKIN]);
+               SDT_PROBE2(usb, umass, device, attach__done,  sc, err);
                umass_disco(sc);
                return;
        }
@@ -568,6 +631,7 @@
                if (err) {
                        aprint_error_dev(self, "couldn't open %u-in (intr)\n",
                            sc->sc_epaddr[UMASS_INTRIN]);
+                       SDT_PROBE2(usb, umass, device, attach__done,  sc, err);
                        umass_disco(sc);
                        return;
                }
@@ -677,6 +741,7 @@
        default:
        fail_create:
                aprint_error_dev(self, "failed to create xfers\n");
+               SDT_PROBE2(usb, umass, device, attach__done,  sc, err);
                umass_disco(sc);
                return;
        }
@@ -765,6 +830,8 @@
        }
        if (error) {
                aprint_error_dev(self, "bus attach failed\n");
+               SDT_PROBE2(usb, umass, device, attach__done,
+                   sc, USBD_IOERROR);
                umass_disco(sc);
                return;
        }
@@ -777,6 +844,7 @@
        DPRINTFM(UDMASS_GEN, "sc %#jx: Attach finished", (uintptr_t)sc,
            0, 0, 0);
 
+       SDT_PROBE2(usb, umass, device, attach__done,  sc, 0);
        return;
 }
 
@@ -799,6 +867,7 @@
        int rv = 0, i;
 
        DPRINTFM(UDMASS_USB, "sc %#jx detached", (uintptr_t)sc, 0, 0, 0);
+       SDT_PROBE1(usb, umass, device, detach__start,  sc);
 
        mutex_enter(&sc->sc_lock);
        sc->sc_dying = true;
@@ -866,8 +935,8 @@
                KASSERT(sc->bus == NULL);
        }
 
-       if (rv != 0)
-               return rv;
+       if (rv)
+               goto out;
 
        umass_disco(sc);
 
@@ -876,6 +945,7 @@
        mutex_destroy(&sc->sc_lock);
        cv_destroy(&sc->sc_detach_cv);
 
+out:   SDT_PROBE2(usb, umass, device, detach__done,  sc, rv);
        return rv;
 }
 
@@ -1022,6 +1092,14 @@
        UMASSHIST_FUNC(); UMASSHIST_CALLED();
 
        sc->transfer_state = TSTATE_IDLE;
+       SDT_PROBE7(usb, umass, transfer, done,
+           sc,
+           sc->transfer_cb,
+           sc->transfer_priv,
+           sc->transfer_data,
+           sc->transfer_datalen,
+           residue,
+           status);
        sc->transfer_cb(sc, sc->transfer_priv, residue, status);
 }
 
@@ -1031,9 +1109,18 @@
        UMASSHIST_FUNC(); UMASSHIST_CALLED();
 
        sc->transfer_state = TSTATE_IDLE;
-       if (sc->transfer_priv)
+       if (sc->transfer_priv) {
+               SDT_PROBE7(usb, umass, transfer, done,
+                   sc,
+                   sc->transfer_cb,
+                   sc->transfer_priv,
+                   sc->transfer_data,
+                   sc->transfer_datalen,
+                   sc->transfer_datalen,
+                   sc->transfer_status);
                sc->transfer_cb(sc, sc->transfer_priv, sc->transfer_datalen,
                    sc->transfer_status);
+       }
 }
 
 #if 0
@@ -1056,6 +1143,7 @@
 umass_bbb_reset(struct umass_softc *sc, int status)
 {
        UMASSHIST_FUNC(); UMASSHIST_CALLED();
+       SDT_PROBE2(usb, umass, bbb, reset,  sc, status);
        KASSERTMSG(sc->sc_wire & UMASS_WPROTO_BBB,
                   "sc->sc_wire == 0x%02x wrong for umass_bbb_reset\n",
                   sc->sc_wire);
@@ -1103,6 +1191,8 @@
                   int flags, umass_callback cb, void *priv)
 {
        UMASSHIST_FUNC(); UMASSHIST_CALLED();
+       SDT_PROBE7(usb, umass, transfer, start__bbb,
+           sc, cb, priv, data, datalen, dir, timeout);
        static int dCBWtag = 42;        /* unique for CBW of transfer */
 
        DPRINTFM(UDMASS_BBB, "sc %#jx cmd=0x%02jx", (uintptr_t)sc,
@@ -1113,6 +1203,8 @@
                   sc->sc_wire);
 
        if (sc->sc_dying) {
+               SDT_PROBE7(usb, umass, transfer, done,
+                   sc, cb, priv, data, datalen, datalen, STATUS_WIRE_FAILED);
                cb(sc, priv, datalen, STATUS_WIRE_FAILED);
                return;
        }
@@ -1226,6 +1318,8 @@
        struct usbd_xfer *next_xfer;
        int residue;
 
+       SDT_PROBE3(usb, umass, bbb, state,  sc, xfer, err);
+
        KASSERTMSG(sc->sc_wire & UMASS_WPROTO_BBB,
                   "sc->sc_wire == 0x%02x wrong for umass_bbb_state\n",
                   sc->sc_wire);
@@ -1567,6 +1661,7 @@
 umass_cbi_reset(struct umass_softc *sc, int status)
 {
        UMASSHIST_FUNC(); UMASSHIST_CALLED();
+       SDT_PROBE2(usb, umass, bbb, reset,  sc, status);
        int i;
 #      define SEND_DIAGNOSTIC_CMDLEN   12
 
@@ -1625,6 +1720,8 @@
                   u_int timeout, int flags, umass_callback cb, void *priv)
 {
        UMASSHIST_FUNC(); UMASSHIST_CALLED();
+       SDT_PROBE7(usb, umass, transfer, start__cbi,
+           sc, cb, priv, data, datalen, dir, timeout);
 
        DPRINTFM(UDMASS_CBI, "sc %#jx: cmd=0x%02jx, len=%jd",
             (uintptr_t)sc, *(u_char *)cmd, datalen, 0);
@@ -1634,6 +1731,8 @@
                   sc->sc_wire);



Home | Main Index | Thread Index | Old Index