diff options
-rw-r--r-- | sys/dev/usb/usb_subr.c | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/sys/dev/usb/usb_subr.c b/sys/dev/usb/usb_subr.c index 95d3fe5a2a2..74ea79ea9e4 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.46 2006/07/16 02:01:37 dlg Exp $ */ +/* $OpenBSD: usb_subr.c,v 1.47 2006/07/17 05:24:16 miod 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 $ */ @@ -848,7 +848,7 @@ usbd_probe_and_attach(device_ptr_t parent, usbd_device_handle dev, int port, int found, i, confi, nifaces, len; usbd_status err; device_ptr_t dv; - usbd_interface_handle ifaces[256]; /* 256 is the absolute max */ + usbd_interface_handle *ifaces; uaa.device = dev; uaa.iface = NULL; @@ -897,6 +897,10 @@ usbd_probe_and_attach(device_ptr_t parent, usbd_device_handle dev, int port, } nifaces = dev->cdesc->bNumInterface; uaa.configno = dev->cdesc->bConfigurationValue; + ifaces = malloc(nifaces * sizeof(usbd_interface_handle), + M_USB, M_NOWAIT); + if (ifaces == NULL) + return (USBD_NOMEM); for (i = 0; i < nifaces; i++) ifaces[i] = &dev->ifaces[i]; uaa.ifaces = ifaces; @@ -904,6 +908,7 @@ usbd_probe_and_attach(device_ptr_t parent, usbd_device_handle dev, int port, len = (nifaces+1) * sizeof dv; dev->subdevs = malloc(len, M_USB, M_NOWAIT); if (dev->subdevs == NULL) { + free(ifaces, M_USB); return (USBD_NOMEM); } bzero(dev->subdevs, len); @@ -919,9 +924,10 @@ usbd_probe_and_attach(device_ptr_t parent, usbd_device_handle dev, int port, if (dv != NULL) { dev->subdevs[found++] = dv; - ifaces[i] = 0; /* consumed */ + ifaces[i] = NULL; /* consumed */ } } + free(ifaces, M_USB); if (found != 0) { return (USBD_NORMAL_COMPLETION); } |