summaryrefslogtreecommitdiff
path: root/drivers/usb/gadget
diff options
context:
space:
mode:
authorMike Lockwood <lockwood@android.com>2011-07-21 11:39:17 -0700
committerDan Willemsen <dwillemsen@nvidia.com>2011-11-30 21:38:53 -0800
commit349eb32284604c038a5a3a0a3aaa52282a6ee528 (patch)
tree34b76712ed3b8754795faaa0f4493a5423db2bb4 /drivers/usb/gadget
parentddea761d060d85fd4ecac1f522fa2f64ec16ce00 (diff)
USB: gadget: f_accessory: Add ioctl to detect USB accessory attached at boot
Signed-off-by: Mike Lockwood <lockwood@android.com>
Diffstat (limited to 'drivers/usb/gadget')
-rw-r--r--drivers/usb/gadget/f_accessory.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/drivers/usb/gadget/f_accessory.c b/drivers/usb/gadget/f_accessory.c
index 873ab2ed991e..05e65e5cd704 100644
--- a/drivers/usb/gadget/f_accessory.c
+++ b/drivers/usb/gadget/f_accessory.c
@@ -75,6 +75,9 @@ struct acc_dev {
/* for acc_complete_set_string */
int string_index;
+ /* set to 1 if we have a pending start request */
+ int start_requested;
+
/* synchronize access to our device file */
atomic_t open_excl;
@@ -505,6 +508,8 @@ static long acc_ioctl(struct file *fp, unsigned code, unsigned long value)
case ACCESSORY_GET_STRING_SERIAL:
src = dev->serial;
break;
+ case ACCESSORY_IS_START_REQUESTED:
+ return dev->start_requested;
}
if (!src)
return -EINVAL;
@@ -572,6 +577,7 @@ static int acc_ctrlrequest(struct usb_composite_dev *cdev,
if (b_requestType == (USB_DIR_OUT | USB_TYPE_VENDOR)) {
if (b_request == ACCESSORY_START) {
+ dev->start_requested = 1;
schedule_delayed_work(
&dev->work, msecs_to_jiffies(10));
value = 0;
@@ -593,6 +599,7 @@ static int acc_ctrlrequest(struct usb_composite_dev *cdev,
memset(dev->version, 0, sizeof(dev->version));
memset(dev->uri, 0, sizeof(dev->uri));
memset(dev->serial, 0, sizeof(dev->serial));
+ dev->start_requested = 0;
}
}
@@ -624,6 +631,8 @@ acc_function_bind(struct usb_configuration *c, struct usb_function *f)
DBG(cdev, "acc_function_bind dev: %p\n", dev);
+ dev->start_requested = 0;
+
/* allocate interface ID(s) */
id = usb_interface_id(c, f);
if (id < 0)