From 9d49fcdb377f698366ba0bd7f45efd85a607652b Mon Sep 17 00:00:00 2001 From: cinap_lenrek Date: Thu, 1 Jan 1970 01:34:55 +0100 Subject: nusb: handle sub hubs --- sys/src/cmd/nusb/usbd/fns.h | 1 + sys/src/cmd/nusb/usbd/usbd.c | 11 +++++++++++ 2 files changed, 12 insertions(+) diff --git a/sys/src/cmd/nusb/usbd/fns.h b/sys/src/cmd/nusb/usbd/fns.h index 7f016536f..f6f2add65 100644 --- a/sys/src/cmd/nusb/usbd/fns.h +++ b/sys/src/cmd/nusb/usbd/fns.h @@ -1,2 +1,3 @@ int startdev(Port*); void work(void); +Hub* newhub(char *, Dev *); diff --git a/sys/src/cmd/nusb/usbd/usbd.c b/sys/src/cmd/nusb/usbd/usbd.c index 79990e233..97059e11d 100644 --- a/sys/src/cmd/nusb/usbd/usbd.c +++ b/sys/src/cmd/nusb/usbd/usbd.c @@ -311,6 +311,17 @@ startdev(Port *p) fprint(2, "okay what?\n"); return -1; } + if(d->usb->class == Clhub){ + /* + * Hubs are handled directly by this process avoiding + * concurrent operation so that at most one device + * has the config address in use. + * We cancel kernel debug for these eps. too chatty. + */ + if((p->hub = newhub(d->dir, d)) == nil) + return -1; + return 0; + } close(d->dfd); d->dfd = -1; pushevent(formatdev(d)); -- cgit v1.2.3