aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/usb/gadget/composite.c
diff options
context:
space:
mode:
authorParirajan Muthalagu <parirajan.muthalagu@stericsson.com>2010-08-25 07:03:26 -0400
committerGreg Kroah-Hartman <gregkh@suse.de>2010-10-22 13:21:20 -0400
commit37b5801e16d2e192fe2b20f4af33aa8c6e8786f3 (patch)
treef38d8549d967faac894c6f1b7e861a7482a9a8c0 /drivers/usb/gadget/composite.c
parent90593899de83a6e6fdea563d058acd2f4334e3f9 (diff)
USB Gadget: Verify VBUS current before setting the device self-powered bit
Acked-by: David Brownell <dbrownell@users.sourceforge.net> Acked-by: Linus Walleij <linus.walleij@stericsson.com> Signed-off-by: Praveena Nadahally <praveen.nadahally@stericsson.com> Signed-off-by: Parirajan Muthalagu <parirajan.muthalagu@stericsson.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/usb/gadget/composite.c')
-rw-r--r--drivers/usb/gadget/composite.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/drivers/usb/gadget/composite.c b/drivers/usb/gadget/composite.c
index 1160c55de7f2..eaa9a599df63 100644
--- a/drivers/usb/gadget/composite.c
+++ b/drivers/usb/gadget/composite.c
@@ -1074,7 +1074,13 @@ static int composite_bind(struct usb_gadget *gadget)
1074 cdev->bufsiz = USB_BUFSIZ; 1074 cdev->bufsiz = USB_BUFSIZ;
1075 cdev->driver = composite; 1075 cdev->driver = composite;
1076 1076
1077 usb_gadget_set_selfpowered(gadget); 1077 /*
1078 * As per USB compliance update, a device that is actively drawing
1079 * more than 100mA from USB must report itself as bus-powered in
1080 * the GetStatus(DEVICE) call.
1081 */
1082 if (CONFIG_USB_GADGET_VBUS_DRAW <= USB_SELF_POWER_VBUS_MAX_DRAW)
1083 usb_gadget_set_selfpowered(gadget);
1078 1084
1079 /* interface and string IDs start at zero via kzalloc. 1085 /* interface and string IDs start at zero via kzalloc.
1080 * we force endpoints to start unassigned; few controller 1086 * we force endpoints to start unassigned; few controller