diff options
-rw-r--r-- | Documentation/ABI/testing/sysfs-devices-platform-_UDC_-gadget | 9 | ||||
-rw-r--r-- | drivers/usb/gadget/composite.c | 21 | ||||
-rw-r--r-- | include/linux/usb/composite.h | 1 | ||||
-rw-r--r-- | include/linux/usb/gadget.h | 4 |
4 files changed, 35 insertions, 0 deletions
diff --git a/Documentation/ABI/testing/sysfs-devices-platform-_UDC_-gadget b/Documentation/ABI/testing/sysfs-devices-platform-_UDC_-gadget new file mode 100644 index 000000000000..34034027b13c --- /dev/null +++ b/Documentation/ABI/testing/sysfs-devices-platform-_UDC_-gadget | |||
@@ -0,0 +1,9 @@ | |||
1 | What: /sys/devices/platform/_UDC_/gadget/suspended | ||
2 | Date: April 2010 | ||
3 | Contact: Fabien Chouteau <fabien.chouteau@barco.com> | ||
4 | Description: | ||
5 | Show the suspend state of an USB composite gadget. | ||
6 | 1 -> suspended | ||
7 | 0 -> resumed | ||
8 | |||
9 | (_UDC_ is the name of the USB Device Controller driver) | ||
diff --git a/drivers/usb/gadget/composite.c b/drivers/usb/gadget/composite.c index 5465d8767f9a..f9aff1bbcb3e 100644 --- a/drivers/usb/gadget/composite.c +++ b/drivers/usb/gadget/composite.c | |||
@@ -898,6 +898,18 @@ static void composite_disconnect(struct usb_gadget *gadget) | |||
898 | 898 | ||
899 | /*-------------------------------------------------------------------------*/ | 899 | /*-------------------------------------------------------------------------*/ |
900 | 900 | ||
901 | static ssize_t composite_show_suspended(struct device *dev, | ||
902 | struct device_attribute *attr, | ||
903 | char *buf) | ||
904 | { | ||
905 | struct usb_gadget *gadget = dev_to_usb_gadget(dev); | ||
906 | struct usb_composite_dev *cdev = get_gadget_data(gadget); | ||
907 | |||
908 | return sprintf(buf, "%d\n", cdev->suspended); | ||
909 | } | ||
910 | |||
911 | static DEVICE_ATTR(suspended, 0444, composite_show_suspended, NULL); | ||
912 | |||
901 | static void /* __init_or_exit */ | 913 | static void /* __init_or_exit */ |
902 | composite_unbind(struct usb_gadget *gadget) | 914 | composite_unbind(struct usb_gadget *gadget) |
903 | { | 915 | { |
@@ -944,6 +956,7 @@ composite_unbind(struct usb_gadget *gadget) | |||
944 | } | 956 | } |
945 | kfree(cdev); | 957 | kfree(cdev); |
946 | set_gadget_data(gadget, NULL); | 958 | set_gadget_data(gadget, NULL); |
959 | device_remove_file(&gadget->dev, &dev_attr_suspended); | ||
947 | composite = NULL; | 960 | composite = NULL; |
948 | } | 961 | } |
949 | 962 | ||
@@ -1036,6 +1049,10 @@ static int __init composite_bind(struct usb_gadget *gadget) | |||
1036 | string_override(composite->strings, | 1049 | string_override(composite->strings, |
1037 | cdev->desc.iSerialNumber, iSerialNumber); | 1050 | cdev->desc.iSerialNumber, iSerialNumber); |
1038 | 1051 | ||
1052 | status = device_create_file(&gadget->dev, &dev_attr_suspended); | ||
1053 | if (status) | ||
1054 | goto fail; | ||
1055 | |||
1039 | INFO(cdev, "%s ready\n", composite->name); | 1056 | INFO(cdev, "%s ready\n", composite->name); |
1040 | return 0; | 1057 | return 0; |
1041 | 1058 | ||
@@ -1064,6 +1081,8 @@ composite_suspend(struct usb_gadget *gadget) | |||
1064 | } | 1081 | } |
1065 | if (composite->suspend) | 1082 | if (composite->suspend) |
1066 | composite->suspend(cdev); | 1083 | composite->suspend(cdev); |
1084 | |||
1085 | cdev->suspended = 1; | ||
1067 | } | 1086 | } |
1068 | 1087 | ||
1069 | static void | 1088 | static void |
@@ -1084,6 +1103,8 @@ composite_resume(struct usb_gadget *gadget) | |||
1084 | f->resume(f); | 1103 | f->resume(f); |
1085 | } | 1104 | } |
1086 | } | 1105 | } |
1106 | |||
1107 | cdev->suspended = 0; | ||
1087 | } | 1108 | } |
1088 | 1109 | ||
1089 | /*-------------------------------------------------------------------------*/ | 1110 | /*-------------------------------------------------------------------------*/ |
diff --git a/include/linux/usb/composite.h b/include/linux/usb/composite.h index 738ea1a691cb..139353efad34 100644 --- a/include/linux/usb/composite.h +++ b/include/linux/usb/composite.h | |||
@@ -326,6 +326,7 @@ struct usb_composite_dev { | |||
326 | 326 | ||
327 | /* private: */ | 327 | /* private: */ |
328 | /* internals */ | 328 | /* internals */ |
329 | unsigned int suspended:1; | ||
329 | struct usb_device_descriptor desc; | 330 | struct usb_device_descriptor desc; |
330 | struct list_head configs; | 331 | struct list_head configs; |
331 | struct usb_composite_driver *driver; | 332 | struct usb_composite_driver *driver; |
diff --git a/include/linux/usb/gadget.h b/include/linux/usb/gadget.h index f4b7ca516cdd..db6141cdb77b 100644 --- a/include/linux/usb/gadget.h +++ b/include/linux/usb/gadget.h | |||
@@ -494,6 +494,10 @@ static inline void set_gadget_data(struct usb_gadget *gadget, void *data) | |||
494 | { dev_set_drvdata(&gadget->dev, data); } | 494 | { dev_set_drvdata(&gadget->dev, data); } |
495 | static inline void *get_gadget_data(struct usb_gadget *gadget) | 495 | static inline void *get_gadget_data(struct usb_gadget *gadget) |
496 | { return dev_get_drvdata(&gadget->dev); } | 496 | { return dev_get_drvdata(&gadget->dev); } |
497 | static inline struct usb_gadget *dev_to_usb_gadget(struct device *dev) | ||
498 | { | ||
499 | return container_of(dev, struct usb_gadget, dev); | ||
500 | } | ||
497 | 501 | ||
498 | /* iterates the non-control endpoints; 'tmp' is a struct usb_ep pointer */ | 502 | /* iterates the non-control endpoints; 'tmp' is a struct usb_ep pointer */ |
499 | #define gadget_for_each_ep(tmp,gadget) \ | 503 | #define gadget_for_each_ep(tmp,gadget) \ |