summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJacob Meuser <jakemsr@cvs.openbsd.org>2010-09-23 05:28:58 +0000
committerJacob Meuser <jakemsr@cvs.openbsd.org>2010-09-23 05:28:58 +0000
commit76bc9d27aac9908dd59bf4e39f2597381c872cd3 (patch)
tree0ad064cfc5bb7b93483df3458c5626560d2d1b3b
parentf66d54f42dbef212c533b94dc8d95b0cf9b20bc9 (diff)
instead of waiting the full power-up-to-power-steady time for root
hubs before their first port explore, check how long it's actually been since power up and only wait as necessary. saves a little time on boot, especially now that explore tasks are serialized. ok yuo@
-rw-r--r--sys/dev/usb/usb.c15
1 files changed, 12 insertions, 3 deletions
diff --git a/sys/dev/usb/usb.c b/sys/dev/usb/usb.c
index 1a10c2a5d9d..04fd7192c47 100644
--- a/sys/dev/usb/usb.c
+++ b/sys/dev/usb/usb.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: usb.c,v 1.65 2010/09/23 04:58:02 jakemsr Exp $ */
+/* $OpenBSD: usb.c,v 1.66 2010/09/23 05:28:57 jakemsr Exp $ */
/* $NetBSD: usb.c,v 1.77 2003/01/01 00:10:26 thorpej Exp $ */
/*
@@ -54,6 +54,7 @@
#include <sys/selinfo.h>
#include <sys/vnode.h>
#include <sys/signalvar.h>
+#include <sys/time.h>
#include <dev/usb/usb.h>
#include <dev/usb/usbdi.h>
@@ -97,6 +98,7 @@ struct usb_softc {
struct usb_task sc_explore_task;
char sc_dying;
+ struct timeval sc_ptime;
};
TAILQ_HEAD(, usb_task) usb_explore_tasks;
@@ -237,6 +239,7 @@ usb_attach(struct device *parent, struct device *self, void *aux)
sc->sc_bus->use_polling--;
if (!sc->sc_dying) {
+ getmicrouptime(&sc->sc_ptime);
if (sc->sc_bus->usbrev == USBREV_2_0)
explore_pending++;
config_pending_incr();
@@ -320,12 +323,18 @@ void
usb_first_explore(void *arg)
{
struct usb_softc *sc = arg;
- int pwrdly;
+ struct timeval now, waited;
+ int pwrdly, waited_ms;
+
+ getmicrouptime(&now);
+ timersub(&now, &sc->sc_ptime, &waited);
+ waited_ms = waited.tv_sec * 1000 + waited.tv_usec / 1000;
/* Wait for power to come good. */
pwrdly = sc->sc_bus->root_hub->hub->hubdesc.bPwrOn2PwrGood *
UHD_PWRON_FACTOR + USB_EXTRA_POWER_UP_TIME;
- usb_delay_ms(sc->sc_bus, pwrdly);
+ if (pwrdly > waited_ms)
+ usb_delay_ms(sc->sc_bus, pwrdly - waited_ms);
/*
* USB1 waits for USB2 to finish their first probe.