summaryrefslogtreecommitdiff
path: root/firmware/usbstack/drivers/device/usb_storage.c
diff options
context:
space:
mode:
authorChristian Gmeiner <christian.gmeiner@gmail.com>2007-09-06 07:17:54 +0000
committerChristian Gmeiner <christian.gmeiner@gmail.com>2007-09-06 07:17:54 +0000
commitdb4753e92445d1a6008e8bf6ab6afdfc12ff874a (patch)
treeaa0a842038a0cc44ba7cf73137e9a138be7f50dc /firmware/usbstack/drivers/device/usb_storage.c
parentdbc6b4e39a8f68708bc20a7b3295662c7871856a (diff)
downloadrockbox-db4753e92445d1a6008e8bf6ab6afdfc12ff874a.zip
rockbox-db4753e92445d1a6008e8bf6ab6afdfc12ff874a.tar.gz
rockbox-db4753e92445d1a6008e8bf6ab6afdfc12ff874a.tar.bz2
rockbox-db4753e92445d1a6008e8bf6ab6afdfc12ff874a.tar.xz
usb stack: add support for standard request get string
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@14626 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'firmware/usbstack/drivers/device/usb_storage.c')
-rw-r--r--firmware/usbstack/drivers/device/usb_storage.c32
1 files changed, 27 insertions, 5 deletions
diff --git a/firmware/usbstack/drivers/device/usb_storage.c b/firmware/usbstack/drivers/device/usb_storage.c
index 49644e5..45fd5c1 100644
--- a/firmware/usbstack/drivers/device/usb_storage.c
+++ b/firmware/usbstack/drivers/device/usb_storage.c
@@ -46,6 +46,21 @@ struct usb_device_driver usb_storage_driver = {
/*-------------------------------------------------------------------------*/
/* usb descriptors */
+#define MANUFACTURER_STR_ID 1
+#define PRODUCT_STR_ID 2
+#define SERIAL_STR_ID 3
+#define CONFIG_STR_ID 4
+#define DATA_STR_ID 5
+
+/* static strings, in UTF-8 */
+static struct usb_string strings[] = {
+ { MANUFACTURER_STR_ID, "RockBox" },
+ { PRODUCT_STR_ID, "RockBox Storage Driver" },
+ { SERIAL_STR_ID, "0" },
+ { CONFIG_STR_ID, "Storage Bulk" },
+ { DATA_STR_ID, "Storage Data" },
+};
+
static struct usb_device_descriptor storage_device_desc = {
.bLength = USB_DT_DEVICE_SIZE,
.bDescriptorType = USB_DT_DEVICE,
@@ -55,9 +70,9 @@ static struct usb_device_descriptor storage_device_desc = {
.bDeviceProtocol = 0,
.idVendor = 0xffff,
.idProduct = 0x0001,
- .iManufacturer = 0,
- .iProduct = 0,
- .iSerialNumber = 0,
+ .iManufacturer = MANUFACTURER_STR_ID,
+ .iProduct = PRODUCT_STR_ID,
+ .iSerialNumber = SERIAL_STR_ID,
.bNumConfigurations = 1,
};
@@ -67,7 +82,7 @@ static struct usb_config_descriptor storage_config_desc = {
.bNumInterfaces = 1,
.bConfigurationValue = 1,
- .iConfiguration = 0,
+ .iConfiguration = CONFIG_STR_ID,
.bmAttributes = USB_CONFIG_ATT_ONE | USB_CONFIG_ATT_SELFPOWER,
.bMaxPower = 1,
};
@@ -80,7 +95,7 @@ static struct usb_interface_descriptor storage_interface_desc = {
.bInterfaceClass = USB_CLASS_MASS_STORAGE,
.bInterfaceSubClass = SUBCL_SCSI,
.bInterfaceProtocol = PROTO_BULK,
- .iInterface = 0,
+ .iInterface = DATA_STR_ID,
};
static struct usb_endpoint_descriptor storage_fs_bulk_in_desc = {
@@ -246,6 +261,13 @@ int usb_storage_driver_request(struct usb_ctrlrequest* request)
}
res.buf = buf;
break;
+
+ case USB_DT_STRING:
+ logf("usb storage: sending string desc");
+ ret = usb_stack_get_string(strings, request->wValue & 0xff, buf);
+ ret = MIN(ret, request->wLength);
+ res.buf = buf;
+ break;
}
break;