drivers: usb: gadget: handle NULL descriptors in composite config_buf
authorJared Suttles <jared.suttles@motorola.com>
Thu, 30 Jul 2009 21:13:27 +0000 (16:13 -0500)
committerColin Cross <ccross@android.com>
Tue, 14 Jun 2011 16:08:53 +0000 (09:08 -0700)
This fixes a problem in enumeration after a gadget function is removed.

Submitted on behalf of RaviKumar Vembu <ravi.v@motorola.com>

Signed-off-by: Jared Suttles <jared.suttles@motorola.com>
Signed-off-by: Mike Lockwood <lockwood@android.com>
drivers/usb/gadget/composite.c

index 5cbb1a41c223d7cd0f139cd1dba4c6c2248f69f8..a1a54b4050c8506d93ff7c306aef166aad4d4e8b 100644 (file)
@@ -240,6 +240,7 @@ static int config_buf(struct usb_configuration *config,
        int                             len = USB_BUFSIZ - USB_DT_CONFIG_SIZE;
        struct usb_function             *f;
        int                             status;
+       int                             interfaceCount = 0;
 
        /* write the config descriptor */
        c = buf;
@@ -270,8 +271,16 @@ static int config_buf(struct usb_configuration *config,
                        descriptors = f->hs_descriptors;
                else
                        descriptors = f->descriptors;
-               if (!descriptors)
+               if (!descriptors || descriptors[0] == NULL) {
+                       for (; f != config->interface[interfaceCount];) {
+                               interfaceCount++;
+                               c->bNumInterfaces--;
+                       }
                        continue;
+               }
+               for (; f != config->interface[interfaceCount];)
+                       interfaceCount++;
+
                status = usb_descriptor_fillbuf(next, len,
                        (const struct usb_descriptor_header **) descriptors);
                if (status < 0)