aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/usb
diff options
context:
space:
mode:
authorDavid Lopo <lopo.david@gmail.com>2008-04-18 21:49:01 -0400
committerGreg Kroah-Hartman <gregkh@suse.de>2008-05-02 13:25:54 -0400
commit7a6ad1dd86a45da8f235300349d4abd9ae7d1a21 (patch)
tree28f651aadce98f8037c0682d0a30cf39e0bde13a /drivers/usb
parent7472f38b10c884f47241529d1367f77c2e1b3551 (diff)
usb: gadget zero timer init fix
Initialize timer earlier so if an error occurs allocating USB request or buffer request (zero_bind) Gadget Zero will not hang trying to delete an uninitialized timer (zero_unbind). Signed-off-by: David Lopo <lopo.david@gmail.com> Signed-off-by: David Brownell <dbrownell@users.sourceforge.net> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/usb')
-rw-r--r--drivers/usb/gadget/zero.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/drivers/usb/gadget/zero.c b/drivers/usb/gadget/zero.c
index 9c5057c63327..fce4924dbbe8 100644
--- a/drivers/usb/gadget/zero.c
+++ b/drivers/usb/gadget/zero.c
@@ -1134,6 +1134,10 @@ autoconf_fail:
1134 dev->gadget = gadget; 1134 dev->gadget = gadget;
1135 set_gadget_data(gadget, dev); 1135 set_gadget_data(gadget, dev);
1136 1136
1137 init_timer(&dev->resume);
1138 dev->resume.function = zero_autoresume;
1139 dev->resume.data = (unsigned long) dev;
1140
1137 /* preallocate control response and buffer */ 1141 /* preallocate control response and buffer */
1138 dev->req = usb_ep_alloc_request(gadget->ep0, GFP_KERNEL); 1142 dev->req = usb_ep_alloc_request(gadget->ep0, GFP_KERNEL);
1139 if (!dev->req) 1143 if (!dev->req)
@@ -1165,9 +1169,6 @@ autoconf_fail:
1165 1169
1166 usb_gadget_set_selfpowered(gadget); 1170 usb_gadget_set_selfpowered(gadget);
1167 1171
1168 init_timer(&dev->resume);
1169 dev->resume.function = zero_autoresume;
1170 dev->resume.data = (unsigned long) dev;
1171 if (autoresume) { 1172 if (autoresume) {
1172 source_sink_config.bmAttributes |= USB_CONFIG_ATT_WAKEUP; 1173 source_sink_config.bmAttributes |= USB_CONFIG_ATT_WAKEUP;
1173 loopback_config.bmAttributes |= USB_CONFIG_ATT_WAKEUP; 1174 loopback_config.bmAttributes |= USB_CONFIG_ATT_WAKEUP;