convert pairs of USBHIST_CALLED()+USBHIST_LOG*() into

USBHIST_CALLARGS() calls.  this reduces the number of
kernel history lines consumed by these callers, and
for the +LOGN versions, add useful log info to a
message that just says "called!".

reduces the line spam which means the total info in a
full log is significantly increased.
This commit is contained in:
mrg 2019-08-21 10:48:37 +00:00
parent 116af900a1
commit 52a4543a10
7 changed files with 171 additions and 167 deletions

View File

@ -1,4 +1,4 @@
/* $NetBSD: uhub.c,v 1.142 2019/05/05 03:17:54 mrg Exp $ */ /* $NetBSD: uhub.c,v 1.143 2019/08/21 10:48:37 mrg Exp $ */
/* $FreeBSD: src/sys/dev/usb/uhub.c,v 1.18 1999/11/17 22:33:43 n_hibma Exp $ */ /* $FreeBSD: src/sys/dev/usb/uhub.c,v 1.18 1999/11/17 22:33:43 n_hibma Exp $ */
/* $OpenBSD: uhub.c,v 1.86 2015/06/29 18:27:40 mpi Exp $ */ /* $OpenBSD: uhub.c,v 1.86 2015/06/29 18:27:40 mpi Exp $ */
@ -37,7 +37,7 @@
*/ */
#include <sys/cdefs.h> #include <sys/cdefs.h>
__KERNEL_RCSID(0, "$NetBSD: uhub.c,v 1.142 2019/05/05 03:17:54 mrg Exp $"); __KERNEL_RCSID(0, "$NetBSD: uhub.c,v 1.143 2019/08/21 10:48:37 mrg Exp $");
#ifdef _KERNEL_OPT #ifdef _KERNEL_OPT
#include "opt_usb.h" #include "opt_usb.h"
@ -100,6 +100,8 @@ fail:
#define DPRINTFN(N,FMT,A,B,C,D) USBHIST_LOGN(uhubdebug,N,FMT,A,B,C,D) #define DPRINTFN(N,FMT,A,B,C,D) USBHIST_LOGN(uhubdebug,N,FMT,A,B,C,D)
#define UHUBHIST_FUNC() USBHIST_FUNC() #define UHUBHIST_FUNC() USBHIST_FUNC()
#define UHUBHIST_CALLED(name) USBHIST_CALLED(uhubdebug) #define UHUBHIST_CALLED(name) USBHIST_CALLED(uhubdebug)
#define UHUBHIST_CALLARGS(FMT,A,B,C,D) \
USBHIST_CALLARGS(uhubdebug,FMT,A,B,C,D)
struct uhub_softc { struct uhub_softc {
device_t sc_dev; /* base device */ device_t sc_dev; /* base device */
@ -486,9 +488,8 @@ uhub_explore(struct usbd_device *dev)
int port; int port;
int change, status, reconnect; int change, status, reconnect;
UHUBHIST_FUNC(); UHUBHIST_CALLED(); UHUBHIST_FUNC();
UHUBHIST_CALLARGS("uhub%jd dev=%#jx addr=%jd speed=%ju",
DPRINTFN(10, "uhub%jd dev=%#jx addr=%jd speed=%ju",
device_unit(sc->sc_dev), (uintptr_t)dev, dev->ud_addr, device_unit(sc->sc_dev), (uintptr_t)dev, dev->ud_addr,
dev->ud_speed); dev->ud_speed);
@ -759,8 +760,8 @@ uhub_explore(struct usbd_device *dev)
dev->ud_depth + 1, speed, port, up); dev->ud_depth + 1, speed, port, up);
/* XXX retry a few times? */ /* XXX retry a few times? */
if (err) { if (err) {
DPRINTF("usbd_new_device failed, error %jd", err, 0, 0, DPRINTF("uhub%jd: usbd_new_device failed, error %jd",
0); device_unit(sc->sc_dev), err, 0, 0);
/* Avoid addressing problems by disabling. */ /* Avoid addressing problems by disabling. */
/* usbd_reset_port(dev, port, &up->status); */ /* usbd_reset_port(dev, port, &up->status); */
@ -927,9 +928,8 @@ uhub_intr(struct usbd_xfer *xfer, void *addr, usbd_status status)
{ {
struct uhub_softc *sc = addr; struct uhub_softc *sc = addr;
UHUBHIST_FUNC(); UHUBHIST_CALLED(); UHUBHIST_FUNC(); UHUBHIST_CALLARGS("called! uhub%jd status=%jx",
device_unit(sc->sc_dev), status, 0, 0);
DPRINTFN(5, "uhub%jd", device_unit(sc->sc_dev), 0, 0, 0);
if (status == USBD_STALLED) if (status == USBD_STALLED)
usbd_clear_endpoint_stall_async(sc->sc_ipipe); usbd_clear_endpoint_stall_async(sc->sc_ipipe);

View File

@ -1,4 +1,4 @@
/* $NetBSD: usb.c,v 1.179 2019/05/05 03:17:54 mrg Exp $ */ /* $NetBSD: usb.c,v 1.180 2019/08/21 10:48:37 mrg Exp $ */
/* /*
* Copyright (c) 1998, 2002, 2008, 2012 The NetBSD Foundation, Inc. * Copyright (c) 1998, 2002, 2008, 2012 The NetBSD Foundation, Inc.
@ -37,7 +37,7 @@
*/ */
#include <sys/cdefs.h> #include <sys/cdefs.h>
__KERNEL_RCSID(0, "$NetBSD: usb.c,v 1.179 2019/05/05 03:17:54 mrg Exp $"); __KERNEL_RCSID(0, "$NetBSD: usb.c,v 1.180 2019/08/21 10:48:37 mrg Exp $");
#ifdef _KERNEL_OPT #ifdef _KERNEL_OPT
#include "opt_usb.h" #include "opt_usb.h"
@ -585,10 +585,11 @@ usb_task_thread(void *arg)
struct usb_taskq *taskq; struct usb_taskq *taskq;
bool mpsafe; bool mpsafe;
USBHIST_FUNC(); USBHIST_CALLED(usbdebug);
taskq = arg; taskq = arg;
DPRINTF("start taskq %#jx", (uintptr_t)taskq, 0, 0, 0);
USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "start taskq %#jx",
(uintptr_t)taskq, 0, 0, 0);
mutex_enter(&taskq->lock); mutex_enter(&taskq->lock);
for (;;) { for (;;) {
@ -737,7 +738,7 @@ usbioctl(dev_t devt, u_long cmd, void *data, int flag, struct lwp *l)
struct usb_softc *sc; struct usb_softc *sc;
int unit = minor(devt); int unit = minor(devt);
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC(); USBHIST_CALLARGS(usbdebug, "cmd %#jx", cmd, 0, 0, 0);
if (unit == USB_DEV_MINOR) { if (unit == USB_DEV_MINOR) {
switch (cmd) { switch (cmd) {
@ -765,7 +766,6 @@ usbioctl(dev_t devt, u_long cmd, void *data, int flag, struct lwp *l)
return EIO; return EIO;
int error = 0; int error = 0;
DPRINTF("cmd %#jx", cmd, 0, 0, 0);
switch (cmd) { switch (cmd) {
#ifdef USB_DEBUG #ifdef USB_DEBUG
case USB_SETDEBUG: case USB_SETDEBUG:
@ -1149,9 +1149,8 @@ void
usb_schedsoftintr(struct usbd_bus *bus) usb_schedsoftintr(struct usbd_bus *bus)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "polling=%jd", bus->ub_usepolling, 0, 0, 0);
DPRINTFN(10, "polling=%jd", bus->ub_usepolling, 0, 0, 0);
/* In case the bus never finished setting up. */ /* In case the bus never finished setting up. */
if (__predict_false(bus->ub_soft == NULL)) if (__predict_false(bus->ub_soft == NULL))

View File

@ -1,4 +1,4 @@
/* $NetBSD: usb_mem.c,v 1.70 2017/10/28 00:37:12 pgoyette Exp $ */ /* $NetBSD: usb_mem.c,v 1.71 2019/08/21 10:48:37 mrg Exp $ */
/* /*
* Copyright (c) 1998 The NetBSD Foundation, Inc. * Copyright (c) 1998 The NetBSD Foundation, Inc.
@ -38,7 +38,7 @@
*/ */
#include <sys/cdefs.h> #include <sys/cdefs.h>
__KERNEL_RCSID(0, "$NetBSD: usb_mem.c,v 1.70 2017/10/28 00:37:12 pgoyette Exp $"); __KERNEL_RCSID(0, "$NetBSD: usb_mem.c,v 1.71 2019/08/21 10:48:37 mrg Exp $");
#ifdef _KERNEL_OPT #ifdef _KERNEL_OPT
#include "opt_usb.h" #include "opt_usb.h"
@ -115,8 +115,8 @@ usb_block_allocmem(bus_dma_tag_t tag, size_t size, size_t align,
usb_dma_block_t *b; usb_dma_block_t *b;
int error; int error;
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
DPRINTFN(5, "size=%ju align=%ju", size, align, 0, 0); USBHIST_CALLARGS(usbdebug, "size=%ju align=%ju", size, align, 0, 0);
ASSERT_SLEEPABLE(); ASSERT_SLEEPABLE();
KASSERT(size != 0); KASSERT(size != 0);
@ -236,11 +236,11 @@ usb_valid_block_p(usb_dma_block_t *b, struct usb_dma_block_qh *qh)
Static void Static void
usb_block_freemem(usb_dma_block_t *b) usb_block_freemem(usb_dma_block_t *b)
{ {
USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "size=%ju", b->size, 0, 0, 0);
KASSERT(mutex_owned(&usb_blk_lock)); KASSERT(mutex_owned(&usb_blk_lock));
USBHIST_FUNC(); USBHIST_CALLED(usbdebug);
DPRINTFN(6, "size=%ju", b->size, 0, 0, 0);
#ifdef DEBUG #ifdef DEBUG
LIST_REMOVE(b, next); LIST_REMOVE(b, next);
#endif #endif

View File

@ -1,4 +1,4 @@
/* $NetBSD: usb_subr.c,v 1.237 2019/08/07 08:47:09 maxv Exp $ */ /* $NetBSD: usb_subr.c,v 1.238 2019/08/21 10:48:37 mrg Exp $ */
/* $FreeBSD: src/sys/dev/usb/usb_subr.c,v 1.18 1999/11/17 22:33:47 n_hibma Exp $ */ /* $FreeBSD: src/sys/dev/usb/usb_subr.c,v 1.18 1999/11/17 22:33:47 n_hibma Exp $ */
/* /*
@ -32,7 +32,7 @@
*/ */
#include <sys/cdefs.h> #include <sys/cdefs.h>
__KERNEL_RCSID(0, "$NetBSD: usb_subr.c,v 1.237 2019/08/07 08:47:09 maxv Exp $"); __KERNEL_RCSID(0, "$NetBSD: usb_subr.c,v 1.238 2019/08/21 10:48:37 mrg Exp $");
#ifdef _KERNEL_OPT #ifdef _KERNEL_OPT
#include "opt_compat_netbsd.h" #include "opt_compat_netbsd.h"
@ -313,7 +313,7 @@ usbd_delay_ms(struct usbd_device *dev, u_int ms)
usbd_status usbd_status
usbd_reset_port(struct usbd_device *dev, int port, usb_port_status_t *ps) usbd_reset_port(struct usbd_device *dev, int port, usb_port_status_t *ps)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC(); USBHIST_CALLARGS(usbdebug, "port %jd", port, 0, 0, 0);
usb_device_request_t req; usb_device_request_t req;
usbd_status err; usbd_status err;
int n; int n;
@ -356,7 +356,9 @@ usbd_reset_port(struct usbd_device *dev, int port, usb_port_status_t *ps)
usb_interface_descriptor_t * usb_interface_descriptor_t *
usbd_find_idesc(usb_config_descriptor_t *cd, int ifaceidx, int altidx) usbd_find_idesc(usb_config_descriptor_t *cd, int ifaceidx, int altidx)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "iface/alt idx %jd/%jd",
ifaceidx, altidx, 0, 0);
char *p = (char *)cd; char *p = (char *)cd;
char *end = p + UGETW(cd->wTotalLength); char *end = p + UGETW(cd->wTotalLength);
usb_descriptor_t *desc; usb_descriptor_t *desc;
@ -443,13 +445,14 @@ usbd_find_edesc(usb_config_descriptor_t *cd, int ifaceidx, int altidx,
usbd_status usbd_status
usbd_fill_iface_data(struct usbd_device *dev, int ifaceidx, int altidx) usbd_fill_iface_data(struct usbd_device *dev, int ifaceidx, int altidx)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "ifaceidx=%jd altidx=%jd",
ifaceidx, altidx, 0, 0);
struct usbd_interface *ifc = &dev->ud_ifaces[ifaceidx]; struct usbd_interface *ifc = &dev->ud_ifaces[ifaceidx];
usb_interface_descriptor_t *idesc; usb_interface_descriptor_t *idesc;
char *p, *end; char *p, *end;
int endpt, nendpt; int endpt, nendpt;
DPRINTFN(4, "ifaceidx=%jd altidx=%jd", ifaceidx, altidx, 0, 0);
idesc = usbd_find_idesc(dev->ud_cdesc, ifaceidx, altidx); idesc = usbd_find_idesc(dev->ud_cdesc, ifaceidx, altidx);
if (idesc == NULL) if (idesc == NULL)
return USBD_INVAL; return USBD_INVAL;
@ -542,10 +545,11 @@ usbd_free_iface_data(struct usbd_device *dev, int ifcno)
Static usbd_status Static usbd_status
usbd_set_config(struct usbd_device *dev, int conf) usbd_set_config(struct usbd_device *dev, int conf)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug);
usb_device_request_t req; usb_device_request_t req;
DPRINTFN(5, "dev %#jx conf %jd", (uintptr_t)dev, conf, 0, 0); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "dev %#jx conf %jd",
(uintptr_t)dev, conf, 0, 0);
req.bmRequestType = UT_WRITE_DEVICE; req.bmRequestType = UT_WRITE_DEVICE;
req.bRequest = UR_SET_CONFIG; req.bRequest = UR_SET_CONFIG;
@ -558,7 +562,7 @@ usbd_set_config(struct usbd_device *dev, int conf)
usbd_status usbd_status
usbd_set_config_no(struct usbd_device *dev, int no, int msg) usbd_set_config_no(struct usbd_device *dev, int no, int msg)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC(); USBHIST_CALLARGS(usbdebug, "%jd", no, 0, 0, 0);
usb_config_descriptor_t cd; usb_config_descriptor_t cd;
usbd_status err; usbd_status err;
int index; int index;
@ -566,7 +570,6 @@ usbd_set_config_no(struct usbd_device *dev, int no, int msg)
if (no == USB_UNCONFIG_NO) if (no == USB_UNCONFIG_NO)
return usbd_set_config_index(dev, USB_UNCONFIG_INDEX, msg); return usbd_set_config_index(dev, USB_UNCONFIG_INDEX, msg);
DPRINTFN(5, "%jd", no, 0, 0, 0);
/* Figure out what config index to use. */ /* Figure out what config index to use. */
for (index = 0; index < dev->ud_ddesc.bNumConfigurations; index++) { for (index = 0; index < dev->ud_ddesc.bNumConfigurations; index++) {
err = usbd_get_config_desc(dev, index, &cd); err = usbd_get_config_desc(dev, index, &cd);
@ -581,13 +584,14 @@ usbd_set_config_no(struct usbd_device *dev, int no, int msg)
usbd_status usbd_status
usbd_set_config_index(struct usbd_device *dev, int index, int msg) usbd_set_config_index(struct usbd_device *dev, int index, int msg)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "dev=%#jx index=%jd",
(uintptr_t)dev, index, 0, 0);
usb_config_descriptor_t cd, *cdp; usb_config_descriptor_t cd, *cdp;
usb_bos_descriptor_t *bdp = NULL; usb_bos_descriptor_t *bdp = NULL;
usbd_status err; usbd_status err;
int i, ifcidx, nifc, len, selfpowered, power; int i, ifcidx, nifc, len, selfpowered, power;
DPRINTFN(5, "dev=%#jx index=%jd", (uintptr_t)dev, index, 0, 0);
if (index >= dev->ud_ddesc.bNumConfigurations && if (index >= dev->ud_ddesc.bNumConfigurations &&
index != USB_UNCONFIG_INDEX) { index != USB_UNCONFIG_INDEX) {
@ -806,13 +810,13 @@ usbd_status
usbd_setup_pipe_flags(struct usbd_device *dev, struct usbd_interface *iface, usbd_setup_pipe_flags(struct usbd_device *dev, struct usbd_interface *iface,
struct usbd_endpoint *ep, int ival, struct usbd_pipe **pipe, uint8_t flags) struct usbd_endpoint *ep, int ival, struct usbd_pipe **pipe, uint8_t flags)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "dev=%#jx addr=%jd iface=%#jx ep=%#jx",
(uintptr_t)dev, dev->ud_addr, (uintptr_t)iface, (uintptr_t)ep);
struct usbd_pipe *p; struct usbd_pipe *p;
usbd_status err; usbd_status err;
p = kmem_alloc(dev->ud_bus->ub_pipesize, KM_SLEEP); p = kmem_alloc(dev->ud_bus->ub_pipesize, KM_SLEEP);
DPRINTFN(1, "dev=%#jx addr=%jd iface=%#jx ep=%#jx",
(uintptr_t)dev, dev->ud_addr, (uintptr_t)iface, (uintptr_t)ep);
DPRINTFN(1, "pipe=%#jx", (uintptr_t)p, 0, 0, 0); DPRINTFN(1, "pipe=%#jx", (uintptr_t)p, 0, 0, 0);
p->up_dev = dev; p->up_dev = dev;
p->up_iface = iface; p->up_iface = iface;
@ -1044,13 +1048,13 @@ usbd_status
usbd_probe_and_attach(device_t parent, struct usbd_device *dev, usbd_probe_and_attach(device_t parent, struct usbd_device *dev,
int port, int addr) int port, int addr)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "trying device specific drivers", 0, 0, 0, 0);
usb_device_descriptor_t *dd = &dev->ud_ddesc; usb_device_descriptor_t *dd = &dev->ud_ddesc;
int confi, nifaces; int confi, nifaces;
usbd_status err; usbd_status err;
/* First try with device specific drivers. */ /* First try with device specific drivers. */
DPRINTF("trying device specific drivers", 0, 0, 0, 0);
err = usbd_attachwholedevice(parent, dev, port, 0); err = usbd_attachwholedevice(parent, dev, port, 0);
if (dev->ud_nifaces_claimed || err) if (dev->ud_nifaces_claimed || err)
return err; return err;
@ -1161,13 +1165,12 @@ usbd_reattach_device(device_t parent, struct usbd_device *dev,
usbd_status usbd_status
usbd_get_initial_ddesc(struct usbd_device *dev, usb_device_descriptor_t *desc) usbd_get_initial_ddesc(struct usbd_device *dev, usb_device_descriptor_t *desc)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "dev %#jx", (uintptr_t)dev, 0, 0, 0);
usb_device_request_t req; usb_device_request_t req;
char buf[64]; char buf[64];
int res, actlen; int res, actlen;
DPRINTFN(5, "dev %#jx", (uintptr_t)dev, 0, 0, 0);
req.bmRequestType = UT_READ_DEVICE; req.bmRequestType = UT_READ_DEVICE;
req.bRequest = UR_GET_DESCRIPTOR; req.bRequest = UR_GET_DESCRIPTOR;
USETW2(req.wValue, UDESC_DEVICE, 0); USETW2(req.wValue, UDESC_DEVICE, 0);
@ -1193,7 +1196,9 @@ usbd_status
usbd_new_device(device_t parent, struct usbd_bus *bus, int depth, int speed, usbd_new_device(device_t parent, struct usbd_bus *bus, int depth, int speed,
int port, struct usbd_port *up) int port, struct usbd_port *up)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "bus=%#jx port=%jd depth=%jd speed=%jd",
(uintptr_t)bus, port, depth, speed);
struct usbd_device *dev, *adev; struct usbd_device *dev, *adev;
struct usbd_device *hub; struct usbd_device *hub;
usb_device_descriptor_t *dd; usb_device_descriptor_t *dd;
@ -1203,9 +1208,6 @@ usbd_new_device(device_t parent, struct usbd_bus *bus, int depth, int speed,
int i; int i;
int p; int p;
DPRINTF("bus=%#jx port=%jd depth=%jd speed=%jd",
(uintptr_t)bus, port, depth, speed);
if (bus->ub_methods->ubm_newdev != NULL) if (bus->ub_methods->ubm_newdev != NULL)
return (bus->ub_methods->ubm_newdev)(parent, bus, depth, speed, return (bus->ub_methods->ubm_newdev)(parent, bus, depth, speed,
port, up); port, up);
@ -1455,9 +1457,9 @@ void
usbd_remove_device(struct usbd_device *dev, struct usbd_port *up) usbd_remove_device(struct usbd_device *dev, struct usbd_port *up)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "dev %#jx up %#jx",
DPRINTF("dev %#jx up %#jx", (uintptr_t)dev, (uintptr_t)up, 0, 0); (uintptr_t)dev, (uintptr_t)up, 0, 0);
if (dev->ud_pipe0 != NULL) if (dev->ud_pipe0 != NULL)
usbd_kill_pipe(dev->ud_pipe0); usbd_kill_pipe(dev->ud_pipe0);
@ -1670,15 +1672,15 @@ usb_free_device(struct usbd_device *dev)
int int
usb_disconnect_port(struct usbd_port *up, device_t parent, int flags) usb_disconnect_port(struct usbd_port *up, device_t parent, int flags)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug);
struct usbd_device *dev = up->up_dev; struct usbd_device *dev = up->up_dev;
device_t subdev; device_t subdev;
char subdevname[16]; char subdevname[16];
const char *hubname = device_xname(parent); const char *hubname = device_xname(parent);
int i, rc; int i, rc;
DPRINTFN(3, "up=%#jx dev=%#jx port=%jd", (uintptr_t)up, (uintptr_t)dev, USBHIST_FUNC();
up->up_portno, 0); USBHIST_CALLARGS(usbdebug, "up=%#jx dev=%#jx port=%jd",
(uintptr_t)up, (uintptr_t)dev, up->up_portno, 0);
if (dev == NULL) { if (dev == NULL) {
return 0; return 0;

View File

@ -1,4 +1,4 @@
/* $NetBSD: usbdi.c,v 1.182 2019/02/17 04:17:31 rin Exp $ */ /* $NetBSD: usbdi.c,v 1.183 2019/08/21 10:48:37 mrg Exp $ */
/* /*
* Copyright (c) 1998, 2012, 2015 The NetBSD Foundation, Inc. * Copyright (c) 1998, 2012, 2015 The NetBSD Foundation, Inc.
@ -32,7 +32,7 @@
*/ */
#include <sys/cdefs.h> #include <sys/cdefs.h>
__KERNEL_RCSID(0, "$NetBSD: usbdi.c,v 1.182 2019/02/17 04:17:31 rin Exp $"); __KERNEL_RCSID(0, "$NetBSD: usbdi.c,v 1.183 2019/08/21 10:48:37 mrg Exp $");
#ifdef _KERNEL_OPT #ifdef _KERNEL_OPT
#include "opt_usb.h" #include "opt_usb.h"
@ -76,9 +76,9 @@ static void usbd_request_async_cb(struct usbd_xfer *, void *, usbd_status);
void void
usbd_dump_iface(struct usbd_interface *iface) usbd_dump_iface(struct usbd_interface *iface)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "iface %#jx", (uintptr_t)iface, 0, 0, 0);
USBHIST_LOG(usbdebug, "iface %#jx", (uintptr_t)iface, 0, 0, 0);
if (iface == NULL) if (iface == NULL)
return; return;
USBHIST_LOG(usbdebug, " device = %#jx idesc = %#jx index = %d", USBHIST_LOG(usbdebug, " device = %#jx idesc = %#jx index = %d",
@ -91,9 +91,9 @@ usbd_dump_iface(struct usbd_interface *iface)
void void
usbd_dump_device(struct usbd_device *dev) usbd_dump_device(struct usbd_device *dev)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "dev = %#jx", (uintptr_t)dev, 0, 0, 0);
USBHIST_LOG(usbdebug, "dev = %#jx", (uintptr_t)dev, 0, 0, 0);
if (dev == NULL) if (dev == NULL)
return; return;
USBHIST_LOG(usbdebug, " bus = %#jx default_pipe = %#jx", USBHIST_LOG(usbdebug, " bus = %#jx default_pipe = %#jx",
@ -108,9 +108,9 @@ usbd_dump_device(struct usbd_device *dev)
void void
usbd_dump_endpoint(struct usbd_endpoint *endp) usbd_dump_endpoint(struct usbd_endpoint *endp)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "endp = %#jx", (uintptr_t)endp, 0, 0, 0);
USBHIST_LOG(usbdebug, "endp = %#jx", (uintptr_t)endp, 0, 0, 0);
if (endp == NULL) if (endp == NULL)
return; return;
USBHIST_LOG(usbdebug, " edesc = %#jx refcnt = %jd", USBHIST_LOG(usbdebug, " edesc = %#jx refcnt = %jd",
@ -125,9 +125,9 @@ usbd_dump_queue(struct usbd_pipe *pipe)
{ {
struct usbd_xfer *xfer; struct usbd_xfer *xfer;
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "pipe = %#jx", (uintptr_t)pipe, 0, 0, 0);
USBHIST_LOG(usbdebug, "pipe = %#jx", (uintptr_t)pipe, 0, 0, 0);
SIMPLEQ_FOREACH(xfer, &pipe->up_queue, ux_next) { SIMPLEQ_FOREACH(xfer, &pipe->up_queue, ux_next) {
USBHIST_LOG(usbdebug, " xfer = %#jx", (uintptr_t)xfer, USBHIST_LOG(usbdebug, " xfer = %#jx", (uintptr_t)xfer,
0, 0, 0); 0, 0, 0);
@ -137,9 +137,9 @@ usbd_dump_queue(struct usbd_pipe *pipe)
void void
usbd_dump_pipe(struct usbd_pipe *pipe) usbd_dump_pipe(struct usbd_pipe *pipe)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "pipe = %#jx", (uintptr_t)pipe, 0, 0, 0);
USBHIST_LOG(usbdebug, "pipe = %#jx", (uintptr_t)pipe, 0, 0, 0);
if (pipe == NULL) if (pipe == NULL)
return; return;
usbd_dump_iface(pipe->up_iface); usbd_dump_iface(pipe->up_iface);
@ -171,9 +171,8 @@ usbd_open_pipe_ival(struct usbd_interface *iface, uint8_t address,
usbd_status err; usbd_status err;
int i; int i;
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "iface = %#jx address = 0x%jx flags = 0x%jx",
USBHIST_LOG(usbdebug, "iface = %#jx address = 0x%jx flags = 0x%jx",
(uintptr_t)iface, address, flags, 0); (uintptr_t)iface, address, flags, 0);
for (i = 0; i < iface->ui_idesc->bNumEndpoints; i++) { for (i = 0; i < iface->ui_idesc->bNumEndpoints; i++) {
@ -205,9 +204,8 @@ usbd_open_pipe_intr(struct usbd_interface *iface, uint8_t address,
struct usbd_xfer *xfer; struct usbd_xfer *xfer;
struct usbd_pipe *ipipe; struct usbd_pipe *ipipe;
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "address = 0x%jx flags = 0x%jx len = %jd",
USBHIST_LOG(usbdebug, "address = 0x%jx flags = 0x%jx len = %jd",
address, flags, len, 0); address, flags, len, 0);
err = usbd_open_pipe_ival(iface, address, err = usbd_open_pipe_ival(iface, address,
@ -279,9 +277,7 @@ usbd_transfer(struct usbd_xfer *xfer)
usbd_status err; usbd_status err;
unsigned int size, flags; unsigned int size, flags;
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC(); USBHIST_CALLARGS(usbdebug,
USBHIST_LOG(usbdebug,
"xfer = %#jx, flags = %#jx, pipe = %#jx, running = %jd", "xfer = %#jx, flags = %#jx, pipe = %#jx, running = %jd",
(uintptr_t)xfer, xfer->ux_flags, (uintptr_t)pipe, pipe->up_running); (uintptr_t)xfer, xfer->ux_flags, (uintptr_t)pipe, pipe->up_running);
KASSERT(xfer->ux_status == USBD_NOT_STARTED); KASSERT(xfer->ux_status == USBD_NOT_STARTED);
@ -469,18 +465,19 @@ usbd_alloc_xfer(struct usbd_device *dev, unsigned int nframes)
{ {
struct usbd_xfer *xfer; struct usbd_xfer *xfer;
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
ASSERT_SLEEPABLE(); ASSERT_SLEEPABLE();
xfer = dev->ud_bus->ub_methods->ubm_allocx(dev->ud_bus, nframes); xfer = dev->ud_bus->ub_methods->ubm_allocx(dev->ud_bus, nframes);
if (xfer == NULL) if (xfer == NULL)
return NULL; goto out;
xfer->ux_bus = dev->ud_bus; xfer->ux_bus = dev->ud_bus;
callout_init(&xfer->ux_callout, CALLOUT_MPSAFE); callout_init(&xfer->ux_callout, CALLOUT_MPSAFE);
cv_init(&xfer->ux_cv, "usbxfer"); cv_init(&xfer->ux_cv, "usbxfer");
USBHIST_LOG(usbdebug, "returns %#jx", (uintptr_t)xfer, 0, 0, 0); out:
USBHIST_CALLARGS(usbdebug, "returns %#jx", (uintptr_t)xfer, 0, 0, 0);
return xfer; return xfer;
} }
@ -488,9 +485,9 @@ usbd_alloc_xfer(struct usbd_device *dev, unsigned int nframes)
static usbd_status static usbd_status
usbd_free_xfer(struct usbd_xfer *xfer) usbd_free_xfer(struct usbd_xfer *xfer)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "%#jx", (uintptr_t)xfer, 0, 0, 0);
USBHIST_LOG(usbdebug, "%#jx", (uintptr_t)xfer, 0, 0, 0);
if (xfer->ux_buf) { if (xfer->ux_buf) {
usbd_free_buffer(xfer); usbd_free_buffer(xfer);
} }
@ -794,14 +791,14 @@ usbd_set_interface(struct usbd_interface *iface, int altidx)
usbd_status err; usbd_status err;
void *endpoints; void *endpoints;
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
if (LIST_FIRST(&iface->ui_pipes) != NULL) if (LIST_FIRST(&iface->ui_pipes) != NULL)
return USBD_IN_USE; return USBD_IN_USE;
endpoints = iface->ui_endpoints; endpoints = iface->ui_endpoints;
int nendpt = iface->ui_idesc->bNumEndpoints; int nendpt = iface->ui_idesc->bNumEndpoints;
USBHIST_LOG(usbdebug, "iface %#jx endpoints = %#jx nendpt %jd", USBHIST_CALLARGS(usbdebug, "iface %#jx endpoints = %#jx nendpt %jd",
(uintptr_t)iface, (uintptr_t)endpoints, (uintptr_t)iface, (uintptr_t)endpoints,
iface->ui_idesc->bNumEndpoints, 0); iface->ui_idesc->bNumEndpoints, 0);
err = usbd_fill_iface_data(iface->ui_dev, iface->ui_index, altidx); err = usbd_fill_iface_data(iface->ui_dev, iface->ui_index, altidx);
@ -869,11 +866,11 @@ usbd_ar_pipe(struct usbd_pipe *pipe)
{ {
struct usbd_xfer *xfer; struct usbd_xfer *xfer;
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "pipe = %#jx", (uintptr_t)pipe, 0, 0, 0);
KASSERT(mutex_owned(pipe->up_dev->ud_bus->ub_lock)); KASSERT(mutex_owned(pipe->up_dev->ud_bus->ub_lock));
USBHIST_LOG(usbdebug, "pipe = %#jx", (uintptr_t)pipe, 0, 0, 0);
#ifdef USB_DEBUG #ifdef USB_DEBUG
if (usbdebug > 5) if (usbdebug > 5)
usbd_dump_queue(pipe); usbd_dump_queue(pipe);
@ -907,9 +904,8 @@ usb_transfer_complete(struct usbd_xfer *xfer)
int polling = bus->ub_usepolling; int polling = bus->ub_usepolling;
int repeat = pipe->up_repeat; int repeat = pipe->up_repeat;
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "pipe = %#jx xfer = %#jx status = %jd "
USBHIST_LOG(usbdebug, "pipe = %#jx xfer = %#jx status = %jd "
"actlen = %jd", (uintptr_t)pipe, (uintptr_t)xfer, xfer->ux_status, "actlen = %jd", (uintptr_t)pipe, (uintptr_t)xfer, xfer->ux_status,
xfer->ux_actlen); xfer->ux_actlen);
@ -1028,10 +1024,9 @@ usb_insert_transfer(struct usbd_xfer *xfer)
struct usbd_pipe *pipe = xfer->ux_pipe; struct usbd_pipe *pipe = xfer->ux_pipe;
usbd_status err; usbd_status err;
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC(); USBHIST_CALLARGS(usbdebug,
"xfer = %#jx pipe = %#jx running = %jd timeout = %jd",
USBHIST_LOG(usbdebug, "xfer = %#jx pipe = %#jx running = %jd " (uintptr_t)xfer, (uintptr_t)pipe,
"timeout = %jd", (uintptr_t)xfer, (uintptr_t)pipe,
pipe->up_running, xfer->ux_timeout); pipe->up_running, xfer->ux_timeout);
KASSERT(mutex_owned(pipe->up_dev->ud_bus->ub_lock)); KASSERT(mutex_owned(pipe->up_dev->ud_bus->ub_lock));
@ -1060,7 +1055,7 @@ usbd_start_next(struct usbd_pipe *pipe)
struct usbd_xfer *xfer; struct usbd_xfer *xfer;
usbd_status err; usbd_status err;
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
KASSERT(pipe != NULL); KASSERT(pipe != NULL);
KASSERT(pipe->up_methods != NULL); KASSERT(pipe->up_methods != NULL);
@ -1072,7 +1067,7 @@ usbd_start_next(struct usbd_pipe *pipe)
/* Get next request in queue. */ /* Get next request in queue. */
xfer = SIMPLEQ_FIRST(&pipe->up_queue); xfer = SIMPLEQ_FIRST(&pipe->up_queue);
USBHIST_LOG(usbdebug, "pipe = %#jx, xfer = %#jx", (uintptr_t)pipe, USBHIST_CALLARGS(usbdebug, "pipe = %#jx, xfer = %#jx", (uintptr_t)pipe,
(uintptr_t)xfer, 0, 0); (uintptr_t)xfer, 0, 0);
if (xfer == NULL) { if (xfer == NULL) {
pipe->up_running = 0; pipe->up_running = 0;
@ -1105,10 +1100,13 @@ usbd_status
usbd_do_request_flags(struct usbd_device *dev, usb_device_request_t *req, usbd_do_request_flags(struct usbd_device *dev, usb_device_request_t *req,
void *data, uint16_t flags, int *actlen, uint32_t timeout) void *data, uint16_t flags, int *actlen, uint32_t timeout)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug);
struct usbd_xfer *xfer; struct usbd_xfer *xfer;
usbd_status err; usbd_status err;
USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "dev=%#jx req=%jx flgas=%jx len=%jx",
(uintptr_t)dev, (uintptr_t)req, flags, actlen);
ASSERT_SLEEPABLE(); ASSERT_SLEEPABLE();
size_t len = UGETW(req->wLength); size_t len = UGETW(req->wLength);

View File

@ -1,4 +1,4 @@
/* $NetBSD: usbdi_util.c,v 1.74 2019/07/31 19:40:59 maxv Exp $ */ /* $NetBSD: usbdi_util.c,v 1.75 2019/08/21 10:48:37 mrg Exp $ */
/* /*
* Copyright (c) 1998, 2012 The NetBSD Foundation, Inc. * Copyright (c) 1998, 2012 The NetBSD Foundation, Inc.
@ -31,7 +31,7 @@
*/ */
#include <sys/cdefs.h> #include <sys/cdefs.h>
__KERNEL_RCSID(0, "$NetBSD: usbdi_util.c,v 1.74 2019/07/31 19:40:59 maxv Exp $"); __KERNEL_RCSID(0, "$NetBSD: usbdi_util.c,v 1.75 2019/08/21 10:48:37 mrg Exp $");
#ifdef _KERNEL_OPT #ifdef _KERNEL_OPT
#include "opt_usb.h" #include "opt_usb.h"
@ -62,9 +62,9 @@ usbd_get_desc(struct usbd_device *dev, int type, int index, int len, void *desc)
usb_device_request_t req; usb_device_request_t req;
usbd_status err; usbd_status err;
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "type=%jd, index=%jd, len=%jd",
DPRINTFN(3,"type=%jd, index=%jd, len=%jd", type, index, len, 0); type, index, len, 0);
/* /*
* Provide hard-coded configuration descriptors * Provide hard-coded configuration descriptors
@ -93,10 +93,10 @@ usbd_status
usbd_get_config_desc(struct usbd_device *dev, int confidx, usbd_get_config_desc(struct usbd_device *dev, int confidx,
usb_config_descriptor_t *d) usb_config_descriptor_t *d)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "confidx=%jd", confidx, 0, 0, 0);
usbd_status err; usbd_status err;
DPRINTFN(3, "confidx=%jd", confidx, 0, 0, 0);
err = usbd_get_desc(dev, UDESC_CONFIG, confidx, err = usbd_get_desc(dev, UDESC_CONFIG, confidx,
USB_CONFIG_DESCRIPTOR_SIZE, d); USB_CONFIG_DESCRIPTOR_SIZE, d);
if (err) if (err)
@ -112,9 +112,8 @@ usbd_get_config_desc(struct usbd_device *dev, int confidx,
usbd_status usbd_status
usbd_get_config_desc_full(struct usbd_device *dev, int conf, void *d, int size) usbd_get_config_desc_full(struct usbd_device *dev, int conf, void *d, int size)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC(); USBHIST_CALLARGS(usbdebug, "conf=%jd", conf, 0, 0, 0);
DPRINTFN(3, "conf=%jd", conf, 0, 0, 0);
return usbd_get_desc(dev, UDESC_CONFIG, conf, size, d); return usbd_get_desc(dev, UDESC_CONFIG, conf, size, d);
} }
@ -122,10 +121,10 @@ usbd_status
usbd_get_bos_desc(struct usbd_device *dev, int confidx, usbd_get_bos_desc(struct usbd_device *dev, int confidx,
usb_bos_descriptor_t *d) usb_bos_descriptor_t *d)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "confidx=%jd", confidx, 0, 0, 0);
usbd_status err; usbd_status err;
DPRINTFN(3, "confidx=%jd", confidx, 0, 0, 0);
err = usbd_get_desc(dev, UDESC_BOS, confidx, err = usbd_get_desc(dev, UDESC_BOS, confidx,
USB_BOS_DESCRIPTOR_SIZE, d); USB_BOS_DESCRIPTOR_SIZE, d);
if (err) if (err)
@ -141,9 +140,8 @@ usbd_get_bos_desc(struct usbd_device *dev, int confidx,
usbd_status usbd_status
usbd_get_bos_desc_full(struct usbd_device *dev, int conf, void *d, int size) usbd_get_bos_desc_full(struct usbd_device *dev, int conf, void *d, int size)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC(); USBHIST_CALLARGS(usbdebug, "conf=%jd", conf, 0, 0, 0);
DPRINTFN(3, "conf=%jd", conf, 0, 0, 0);
return usbd_get_desc(dev, UDESC_BOS, conf, size, d); return usbd_get_desc(dev, UDESC_BOS, conf, size, d);
} }
@ -173,10 +171,10 @@ usbd_get_device_status(struct usbd_device *dev, usb_status_t *st)
usbd_status usbd_status
usbd_get_hub_status(struct usbd_device *dev, usb_hub_status_t *st) usbd_get_hub_status(struct usbd_device *dev, usb_hub_status_t *st)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "dev %#jx", (uintptr_t)dev, 0, 0, 0);
usb_device_request_t req; usb_device_request_t req;
DPRINTF("dev %#jx", (uintptr_t)dev, 0, 0, 0);
req.bmRequestType = UT_READ_CLASS_DEVICE; req.bmRequestType = UT_READ_CLASS_DEVICE;
req.bRequest = UR_GET_STATUS; req.bRequest = UR_GET_STATUS;
USETW(req.wValue, 0); USETW(req.wValue, 0);
@ -188,10 +186,11 @@ usbd_get_hub_status(struct usbd_device *dev, usb_hub_status_t *st)
usbd_status usbd_status
usbd_set_address(struct usbd_device *dev, int addr) usbd_set_address(struct usbd_device *dev, int addr)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "dev %#jx addr %jd",
(uintptr_t)dev, addr, 0, 0);
usb_device_request_t req; usb_device_request_t req;
DPRINTF("dev %#jx addr %jd", (uintptr_t)dev, addr, 0, 0);
req.bmRequestType = UT_WRITE_DEVICE; req.bmRequestType = UT_WRITE_DEVICE;
req.bRequest = UR_SET_ADDRESS; req.bRequest = UR_SET_ADDRESS;
USETW(req.wValue, addr); USETW(req.wValue, addr);
@ -203,10 +202,11 @@ usbd_set_address(struct usbd_device *dev, int addr)
usbd_status usbd_status
usbd_get_port_status(struct usbd_device *dev, int port, usb_port_status_t *ps) usbd_get_port_status(struct usbd_device *dev, int port, usb_port_status_t *ps)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "dev %#jx port %jd",
(uintptr_t)dev, port, 0, 0);
usb_device_request_t req; usb_device_request_t req;
DPRINTF("dev %#jx port %jd", (uintptr_t)dev, port, 0, 0);
req.bmRequestType = UT_READ_CLASS_OTHER; req.bmRequestType = UT_READ_CLASS_OTHER;
req.bRequest = UR_GET_STATUS; req.bRequest = UR_GET_STATUS;
USETW(req.wValue, 0); USETW(req.wValue, 0);
@ -220,10 +220,11 @@ usbd_status
usbd_get_port_status_ext(struct usbd_device *dev, int port, usbd_get_port_status_ext(struct usbd_device *dev, int port,
usb_port_status_ext_t *pse) usb_port_status_ext_t *pse)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "dev %#jx port %jd",
(uintptr_t)dev, port, 0, 0);
usb_device_request_t req; usb_device_request_t req;
DPRINTF("dev %#jx port %jd", (uintptr_t)dev, port, 0, 0);
req.bmRequestType = UT_READ_CLASS_OTHER; req.bmRequestType = UT_READ_CLASS_OTHER;
req.bRequest = UR_GET_STATUS; req.bRequest = UR_GET_STATUS;
USETW2(req.wValue, 0, UR_PST_EXT_PORT_STATUS); USETW2(req.wValue, 0, UR_PST_EXT_PORT_STATUS);
@ -235,10 +236,11 @@ usbd_get_port_status_ext(struct usbd_device *dev, int port,
usbd_status usbd_status
usbd_clear_hub_feature(struct usbd_device *dev, int sel) usbd_clear_hub_feature(struct usbd_device *dev, int sel)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "dev %#jx sel %jd",
(uintptr_t)dev, sel, 0, 0);
usb_device_request_t req; usb_device_request_t req;
DPRINTF("dev %#jx sel %jd", (uintptr_t)dev, sel, 0, 0);
req.bmRequestType = UT_WRITE_CLASS_DEVICE; req.bmRequestType = UT_WRITE_CLASS_DEVICE;
req.bRequest = UR_CLEAR_FEATURE; req.bRequest = UR_CLEAR_FEATURE;
USETW(req.wValue, sel); USETW(req.wValue, sel);
@ -250,10 +252,11 @@ usbd_clear_hub_feature(struct usbd_device *dev, int sel)
usbd_status usbd_status
usbd_set_hub_feature(struct usbd_device *dev, int sel) usbd_set_hub_feature(struct usbd_device *dev, int sel)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug,
"dev %#jx sel %jd", (uintptr_t)dev, sel, 0, 0);
usb_device_request_t req; usb_device_request_t req;
DPRINTF("dev %#jx sel %jd", (uintptr_t)dev, sel, 0, 0);
req.bmRequestType = UT_WRITE_CLASS_DEVICE; req.bmRequestType = UT_WRITE_CLASS_DEVICE;
req.bRequest = UR_SET_FEATURE; req.bRequest = UR_SET_FEATURE;
USETW(req.wValue, sel); USETW(req.wValue, sel);
@ -265,10 +268,11 @@ usbd_set_hub_feature(struct usbd_device *dev, int sel)
usbd_status usbd_status
usbd_clear_port_feature(struct usbd_device *dev, int port, int sel) usbd_clear_port_feature(struct usbd_device *dev, int port, int sel)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "dev %#jx port %jd sel %jd",
(uintptr_t)dev, port, sel, 0);
usb_device_request_t req; usb_device_request_t req;
DPRINTF("dev %#jx port %jd sel %jd", (uintptr_t)dev, port, sel, 0);
req.bmRequestType = UT_WRITE_CLASS_OTHER; req.bmRequestType = UT_WRITE_CLASS_OTHER;
req.bRequest = UR_CLEAR_FEATURE; req.bRequest = UR_CLEAR_FEATURE;
USETW(req.wValue, sel); USETW(req.wValue, sel);
@ -280,10 +284,11 @@ usbd_clear_port_feature(struct usbd_device *dev, int port, int sel)
usbd_status usbd_status
usbd_set_port_feature(struct usbd_device *dev, int port, int sel) usbd_set_port_feature(struct usbd_device *dev, int port, int sel)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "dev %#jx port %jd sel %.d",
(uintptr_t)dev, sel, 0, 0);
usb_device_request_t req; usb_device_request_t req;
DPRINTF("dev %#jx port %jd sel %.d", (uintptr_t)dev, sel, 0, 0);
req.bmRequestType = UT_WRITE_CLASS_OTHER; req.bmRequestType = UT_WRITE_CLASS_OTHER;
req.bRequest = UR_SET_FEATURE; req.bRequest = UR_SET_FEATURE;
USETW(req.wValue, sel); USETW(req.wValue, sel);
@ -295,11 +300,11 @@ usbd_set_port_feature(struct usbd_device *dev, int port, int sel)
usbd_status usbd_status
usbd_set_port_u1_timeout(struct usbd_device *dev, int port, int timeout) usbd_set_port_u1_timeout(struct usbd_device *dev, int port, int timeout)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "dev %#jx port %jd timeout %.d",
(uintptr_t)dev, port, timeout, 0);
usb_device_request_t req; usb_device_request_t req;
DPRINTF("dev %#jx port %jd timeout %.d", (uintptr_t)dev, port,
timeout, 0);
req.bmRequestType = UT_WRITE_CLASS_OTHER; req.bmRequestType = UT_WRITE_CLASS_OTHER;
req.bRequest = UR_SET_FEATURE; req.bRequest = UR_SET_FEATURE;
USETW(req.wValue, UHF_PORT_U1_TIMEOUT); USETW(req.wValue, UHF_PORT_U1_TIMEOUT);
@ -311,11 +316,11 @@ usbd_set_port_u1_timeout(struct usbd_device *dev, int port, int timeout)
usbd_status usbd_status
usbd_set_port_u2_timeout(struct usbd_device *dev, int port, int timeout) usbd_set_port_u2_timeout(struct usbd_device *dev, int port, int timeout)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "dev %#jx port %jd timeout %jd",
(uintptr_t)dev, port, timeout, 0);
usb_device_request_t req; usb_device_request_t req;
DPRINTF("dev %#jx port %jd timeout %jd", (uintptr_t)dev, port,
timeout, 0);
req.bmRequestType = UT_WRITE_CLASS_OTHER; req.bmRequestType = UT_WRITE_CLASS_OTHER;
req.bRequest = UR_SET_FEATURE; req.bRequest = UR_SET_FEATURE;
USETW(req.wValue, UHF_PORT_U2_TIMEOUT); USETW(req.wValue, UHF_PORT_U2_TIMEOUT);
@ -331,12 +336,12 @@ usbd_get_protocol(struct usbd_interface *iface, uint8_t *report)
struct usbd_device *dev; struct usbd_device *dev;
usb_device_request_t req; usb_device_request_t req;
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "iface=%#jx, endpt=%jd",
(uintptr_t)iface, id->bInterfaceNumber, 0, 0);
if (id == NULL) if (id == NULL)
return USBD_IOERROR; return USBD_IOERROR;
DPRINTFN(4, "iface=%#jx, endpt=%jd", (uintptr_t)iface,
id->bInterfaceNumber, 0, 0);
usbd_interface2device_handle(iface, &dev); usbd_interface2device_handle(iface, &dev);
req.bmRequestType = UT_READ_CLASS_INTERFACE; req.bmRequestType = UT_READ_CLASS_INTERFACE;
@ -354,12 +359,12 @@ usbd_set_protocol(struct usbd_interface *iface, int report)
struct usbd_device *dev; struct usbd_device *dev;
usb_device_request_t req; usb_device_request_t req;
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "iface=%#jx, report=%jd, endpt=%jd",
(uintptr_t)iface, report, id->bInterfaceNumber, 0);
if (id == NULL) if (id == NULL)
return USBD_IOERROR; return USBD_IOERROR;
DPRINTFN(4, "iface=%#jx, report=%jd, endpt=%jd", (uintptr_t)iface,
report, id->bInterfaceNumber, 0);
usbd_interface2device_handle(iface, &dev); usbd_interface2device_handle(iface, &dev);
req.bmRequestType = UT_WRITE_CLASS_INTERFACE; req.bmRequestType = UT_WRITE_CLASS_INTERFACE;
@ -378,9 +383,9 @@ usbd_set_report(struct usbd_interface *iface, int type, int id, void *data,
struct usbd_device *dev; struct usbd_device *dev;
usb_device_request_t req; usb_device_request_t req;
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "len=%jd", len, 0, 0, 0);
DPRINTFN(4, "len=%jd", len, 0, 0, 0);
if (ifd == NULL) if (ifd == NULL)
return USBD_IOERROR; return USBD_IOERROR;
usbd_interface2device_handle(iface, &dev); usbd_interface2device_handle(iface, &dev);
@ -400,9 +405,8 @@ usbd_get_report(struct usbd_interface *iface, int type, int id, void *data,
struct usbd_device *dev; struct usbd_device *dev;
usb_device_request_t req; usb_device_request_t req;
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC(); USBHIST_CALLARGS(usbdebug, "len=%jd", len, 0, 0, 0);
DPRINTFN(4, "len=%jd", len, 0, 0, 0);
if (ifd == NULL) if (ifd == NULL)
return USBD_IOERROR; return USBD_IOERROR;
usbd_interface2device_handle(iface, &dev); usbd_interface2device_handle(iface, &dev);
@ -421,9 +425,9 @@ usbd_set_idle(struct usbd_interface *iface, int duration, int id)
struct usbd_device *dev; struct usbd_device *dev;
usb_device_request_t req; usb_device_request_t req;
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "duration %jd id %jd", duration, id, 0, 0);
DPRINTFN(4, "duration %jd id %jd", duration, id, 0, 0);
if (ifd == NULL) if (ifd == NULL)
return USBD_IOERROR; return USBD_IOERROR;
usbd_interface2device_handle(iface, &dev); usbd_interface2device_handle(iface, &dev);
@ -439,10 +443,11 @@ usbd_status
usbd_get_report_descriptor(struct usbd_device *dev, int ifcno, usbd_get_report_descriptor(struct usbd_device *dev, int ifcno,
int size, void *d) int size, void *d)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "dev %#jx ifcno %jd size %jd",
(uintptr_t)dev, ifcno, size, 0);
usb_device_request_t req; usb_device_request_t req;
DPRINTF("dev %#jx ifcno %jd size %jd", (uintptr_t)dev, ifcno, size, 0);
req.bmRequestType = UT_READ_INTERFACE; req.bmRequestType = UT_READ_INTERFACE;
req.bRequest = UR_GET_DESCRIPTOR; req.bRequest = UR_GET_DESCRIPTOR;
USETW2(req.wValue, UDESC_REPORT, 0); /* report id should be 0 */ USETW2(req.wValue, UDESC_REPORT, 0); /* report id should be 0 */
@ -512,10 +517,10 @@ usbd_read_report_desc(struct usbd_interface *ifc, void **descp, int *sizep)
usbd_status usbd_status
usbd_get_config(struct usbd_device *dev, uint8_t *conf) usbd_get_config(struct usbd_device *dev, uint8_t *conf)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "dev %#jx", (uintptr_t)dev, 0, 0, 0);
usb_device_request_t req; usb_device_request_t req;
DPRINTF("dev %#jx", (uintptr_t)dev, 0, 0, 0);
req.bmRequestType = UT_READ_DEVICE; req.bmRequestType = UT_READ_DEVICE;
req.bRequest = UR_GET_CONFIG; req.bRequest = UR_GET_CONFIG;
USETW(req.wValue, 0); USETW(req.wValue, 0);
@ -530,10 +535,10 @@ usbd_bulk_transfer(struct usbd_xfer *xfer, struct usbd_pipe *pipe,
{ {
usbd_status err; usbd_status err;
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "start transfer %jd bytes", *size, 0, 0, 0);
usbd_setup_xfer(xfer, 0, buf, *size, flags, timeout, NULL); usbd_setup_xfer(xfer, 0, buf, *size, flags, timeout, NULL);
DPRINTFN(1, "start transfer %jd bytes", *size, 0, 0, 0);
err = usbd_sync_transfer_sig(xfer); err = usbd_sync_transfer_sig(xfer);
usbd_get_xfer_status(xfer, NULL, NULL, size, NULL); usbd_get_xfer_status(xfer, NULL, NULL, size, NULL);
@ -553,11 +558,11 @@ usbd_intr_transfer(struct usbd_xfer *xfer, struct usbd_pipe *pipe,
{ {
usbd_status err; usbd_status err;
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "start transfer %jd bytes", *size, 0, 0, 0);
usbd_setup_xfer(xfer, 0, buf, *size, flags, timeout, NULL); usbd_setup_xfer(xfer, 0, buf, *size, flags, timeout, NULL);
DPRINTFN(1, "start transfer %jd bytes", *size, 0, 0, 0);
err = usbd_sync_transfer_sig(xfer); err = usbd_sync_transfer_sig(xfer);
usbd_get_xfer_status(xfer, NULL, NULL, size, NULL); usbd_get_xfer_status(xfer, NULL, NULL, size, NULL);
@ -575,9 +580,10 @@ usbd_intr_transfer(struct usbd_xfer *xfer, struct usbd_pipe *pipe,
void void
usb_detach_waitold(device_t dv) usb_detach_waitold(device_t dv)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "waiting for dv %#jx",
(uintptr_t)dv, 0, 0, 0);
DPRINTFN(1, "waiting for dv %#jx", (uintptr_t)dv, 0, 0, 0);
if (tsleep(dv, PZERO, "usbdet", hz * 60)) /* XXXSMP ok */ if (tsleep(dv, PZERO, "usbdet", hz * 60)) /* XXXSMP ok */
aprint_error_dev(dv, "usb_detach_waitold: didn't detach\n"); aprint_error_dev(dv, "usb_detach_waitold: didn't detach\n");
DPRINTFN(1, "done", 0, 0, 0, 0); DPRINTFN(1, "done", 0, 0, 0, 0);
@ -586,9 +592,9 @@ usb_detach_waitold(device_t dv)
void void
usb_detach_wakeupold(device_t dv) usb_detach_wakeupold(device_t dv)
{ {
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
USBHIST_CALLARGS(usbdebug, "for dv %#jx", (uintptr_t)dv, 0, 0, 0);
DPRINTFN(1, "for dv %#jx", (uintptr_t)dv, 0, 0, 0);
wakeup(dv); /* XXXSMP ok */ wakeup(dv); /* XXXSMP ok */
} }

View File

@ -1,4 +1,4 @@
/* $NetBSD: usbroothub.c,v 1.8 2019/01/27 02:08:42 pgoyette Exp $ */ /* $NetBSD: usbroothub.c,v 1.9 2019/08/21 10:48:37 mrg Exp $ */
/*- /*-
* Copyright (c) 1998, 2004, 2011, 2012 The NetBSD Foundation, Inc. * Copyright (c) 1998, 2004, 2011, 2012 The NetBSD Foundation, Inc.
@ -58,7 +58,7 @@
*/ */
#include <sys/cdefs.h> #include <sys/cdefs.h>
__KERNEL_RCSID(0, "$NetBSD: usbroothub.c,v 1.8 2019/01/27 02:08:42 pgoyette Exp $"); __KERNEL_RCSID(0, "$NetBSD: usbroothub.c,v 1.9 2019/08/21 10:48:37 mrg Exp $");
#include <dev/usb/usb.h> #include <dev/usb/usb.h>
#include <dev/usb/usbdi.h> #include <dev/usb/usbdi.h>
@ -366,20 +366,20 @@ roothub_ctrl_start(struct usbd_xfer *xfer)
usb_device_request_t *req; usb_device_request_t *req;
usbd_status err = USBD_IOERROR; /* XXX STALL? */ usbd_status err = USBD_IOERROR; /* XXX STALL? */
uint16_t len, value; uint16_t len, value;
int buflen, actlen; int buflen, actlen = -1;
void *buf; void *buf;
USBHIST_FUNC(); USBHIST_CALLED(usbdebug); USBHIST_FUNC();
KASSERT(xfer->ux_rqflags & URQ_REQUEST); KASSERT(xfer->ux_rqflags & URQ_REQUEST);
req = &xfer->ux_request; req = &xfer->ux_request;
USBHIST_LOG(usbdebug, "type=%#2jx request=%#2jx", req->bmRequestType,
req->bRequest, 0, 0);
len = UGETW(req->wLength); len = UGETW(req->wLength);
value = UGETW(req->wValue); value = UGETW(req->wValue);
USBHIST_CALLARGS(usbdebug, "type=%#jx request=%#jx len=%#jx value=%#jx",
req->bmRequestType, req->bRequest, len, value);
buf = len ? usbd_get_buffer(xfer) : NULL; buf = len ? usbd_get_buffer(xfer) : NULL;
buflen = 0; buflen = 0;
@ -553,8 +553,6 @@ roothub_ctrl_start(struct usbd_xfer *xfer)
} }
actlen = bus->ub_methods->ubm_rhctrl(bus, req, buf, buflen); actlen = bus->ub_methods->ubm_rhctrl(bus, req, buf, buflen);
USBHIST_LOG(usbdebug, "xfer %#jx buflen %jd actlen %jd",
(uintptr_t)xfer, buflen, actlen, 0);
if (actlen < 0) if (actlen < 0)
goto fail; goto fail;
@ -562,7 +560,8 @@ roothub_ctrl_start(struct usbd_xfer *xfer)
err = USBD_NORMAL_COMPLETION; err = USBD_NORMAL_COMPLETION;
fail: fail:
USBHIST_LOG(usbdebug, "xfer %#jx err %jd", (uintptr_t)xfer, err, 0, 0); USBHIST_LOG(usbdebug, "xfer %#jx buflen %jd actlen %jd err %jd",
(uintptr_t)xfer, buflen, actlen, err);
xfer->ux_status = err; xfer->ux_status = err;
mutex_enter(bus->ub_lock); mutex_enter(bus->ub_lock);