diff options
author | David Gwynne <dlg@cvs.openbsd.org> | 2004-12-12 06:13:16 +0000 |
---|---|---|
committer | David Gwynne <dlg@cvs.openbsd.org> | 2004-12-12 06:13:16 +0000 |
commit | 4bb5cdd54e7c2da77fd72fea602398df470ff672 (patch) | |
tree | 2bbe34a686a2f59c4e47ae7796052803d8988145 | |
parent | 8284b453e84f70099a958bb4402d18f50f7fd78c (diff) |
backout the original method of reattaching a usb device now that we have
something better and more flexible to use.
-rw-r--r-- | sys/dev/usb/usb_port.h | 5 | ||||
-rw-r--r-- | sys/dev/usb/usb_subr.c | 39 | ||||
-rw-r--r-- | sys/dev/usb/usbdi.h | 3 |
3 files changed, 4 insertions, 43 deletions
diff --git a/sys/dev/usb/usb_port.h b/sys/dev/usb/usb_port.h index dab4ad72e3a..d35379fd545 100644 --- a/sys/dev/usb/usb_port.h +++ b/sys/dev/usb/usb_port.h @@ -1,4 +1,4 @@ -/* $OpenBSD: usb_port.h,v 1.53 2004/11/23 19:08:54 miod Exp $ */ +/* $OpenBSD: usb_port.h,v 1.54 2004/12/12 06:13:15 dlg Exp $ */ /* $NetBSD: usb_port.h,v 1.62 2003/02/15 18:33:30 augustss Exp $ */ /* $FreeBSD: src/sys/dev/usb/usb_port.h,v 1.21 1999/11/17 22:33:47 n_hibma Exp $ */ @@ -175,7 +175,6 @@ void __CONCAT(dname,_attach)(struct device *parent, struct device *self, void *a /* Returns from attach */ #define USB_ATTACH_ERROR_RETURN return #define USB_ATTACH_SUCCESS_RETURN return -#define USB_ATTACH_NEED_RESET return #define USB_ATTACH_SETUP printf("\n") @@ -369,7 +368,6 @@ __CONCAT(dname,_attach)(parent, self, aux) \ /* Returns from attach */ #define USB_ATTACH_ERROR_RETURN return #define USB_ATTACH_SUCCESS_RETURN return -#define USB_ATTACH_NEED_RESET return #define USB_ATTACH_SETUP printf("\n") @@ -494,7 +492,6 @@ __CONCAT(dname,_attach)(device_t self) /* Returns from attach */ #define USB_ATTACH_ERROR_RETURN return ENXIO #define USB_ATTACH_SUCCESS_RETURN return 0 -#define USB_ATTACH_NEED_RESET return EAGAIN #define USB_ATTACH_SETUP \ sc->sc_dev = self; \ diff --git a/sys/dev/usb/usb_subr.c b/sys/dev/usb/usb_subr.c index 6f485ffa0c7..dd66a79118e 100644 --- a/sys/dev/usb/usb_subr.c +++ b/sys/dev/usb/usb_subr.c @@ -1,4 +1,4 @@ -/* $OpenBSD: usb_subr.c,v 1.31 2004/11/08 22:01:02 dlg Exp $ */ +/* $OpenBSD: usb_subr.c,v 1.32 2004/12/12 06:13:15 dlg Exp $ */ /* $NetBSD: usb_subr.c,v 1.103 2003/01/10 11:19:13 augustss Exp $ */ /* $FreeBSD: src/sys/dev/usb/usb_subr.c,v 1.18 1999/11/17 22:33:47 n_hibma Exp $ */ @@ -87,8 +87,6 @@ Static int usbd_submatch(device_ptr_t, struct cfdata *cf, void *); Static int usbd_print(void *aux, const char *pnp); Static int usbd_submatch(device_ptr_t, void *, void *); #endif -Static usbd_status usbd_new_device2(device_ptr_t, usbd_bus_handle, int, int, - int, struct usbd_port *); Static void usbd_free_iface_data(usbd_device_handle dev, int ifcno); Static void usbd_kill_pipe(usbd_pipe_handle); Static usbd_status usbd_probe_and_attach(device_ptr_t parent, @@ -134,7 +132,6 @@ Static const char * const usbd_error_strs[] = { "SHORT_XFER", "STALLED", "INTERRUPTED", - "NEED_RESET", "XXX", }; @@ -921,12 +918,6 @@ usbd_probe_and_attach(device_ptr_t parent, usbd_device_handle dev, uaa.ifaceno = ifaces[i]->idesc->bInterfaceNumber; dv = USB_DO_ATTACH(dev, bdev, parent, &uaa, usbd_print, usbd_submatch); - if (dev->address == USB_START_ADDR) { -#if defined(__FreeBSD__) - device_delete_child(parent, bdev); -#endif - return (USBD_NEED_RESET); - } if (dv != NULL) { dev->subdevs[found++] = dv; @@ -997,7 +988,7 @@ usbd_probe_and_attach(device_ptr_t parent, usbd_device_handle dev, * and attach a driver. */ usbd_status -usbd_new_device2(device_ptr_t parent, usbd_bus_handle bus, int depth, +usbd_new_device(device_ptr_t parent, usbd_bus_handle bus, int depth, int speed, int port, struct usbd_port *up) { usbd_device_handle dev; @@ -1142,11 +1133,6 @@ usbd_new_device2(device_ptr_t parent, usbd_bus_handle bus, int depth, err = usbd_probe_and_attach(parent, dev, port, addr); if (err) { - if (err == USBD_NEED_RESET) { - DPRINTF(("usbd_new_device2: device needs reset\n")); - /* must set address back to what it was */ - dev->address = addr; - } usbd_remove_device(dev, up); return (err); } @@ -1155,27 +1141,6 @@ usbd_new_device2(device_ptr_t parent, usbd_bus_handle bus, int depth, } usbd_status -usbd_new_device(device_ptr_t parent, usbd_bus_handle bus, int depth, - int speed, int ports, struct usbd_port *up) -{ - int retry = 0; - usbd_status err; - - do { - if (retry > 0) - DPRINTF(("usbd_new_device: re-enumerating device\n")); - err = usbd_new_device2(parent, bus, depth, speed, ports, up); - } while ((err == USBD_NEED_RESET) && (retry++ < 5)); - - if (retry == 5) { - DPRINTF(("usbd_new_device: giving up after 5 tries\n")); - return (USBD_NOT_CONFIGURED); - } - - return (err); -} - -usbd_status usbd_reload_device_desc(usbd_device_handle dev) { usbd_status err; diff --git a/sys/dev/usb/usbdi.h b/sys/dev/usb/usbdi.h index 59dd476ad0c..23f0b29868f 100644 --- a/sys/dev/usb/usbdi.h +++ b/sys/dev/usb/usbdi.h @@ -1,4 +1,4 @@ -/* $OpenBSD: usbdi.h,v 1.22 2004/11/08 22:01:02 dlg Exp $ */ +/* $OpenBSD: usbdi.h,v 1.23 2004/12/12 06:13:15 dlg Exp $ */ /* $NetBSD: usbdi.h,v 1.62 2002/07/11 21:14:35 augustss Exp $ */ /* $FreeBSD: src/sys/dev/usb/usbdi.h,v 1.18 1999/11/17 22:33:49 n_hibma Exp $ */ @@ -67,7 +67,6 @@ typedef enum { /* keep in sync with usbd_status_msgs */ USBD_SHORT_XFER, /* 16 */ USBD_STALLED, /* 17 */ USBD_INTERRUPTED, /* 18 */ - USBD_NEED_RESET, /* 19 */ USBD_ERROR_MAX /* must be last */ } usbd_status; |