|
|
@@ -35,32 +35,35 @@
|
|
|
#define USB_PID (0x4000 | _PID_MAP(CDC, 0) | _PID_MAP(MSC, 1) | _PID_MAP(HID, 2) | \
|
|
|
_PID_MAP(MIDI, 3) | _PID_MAP(VENDOR, 4) )
|
|
|
|
|
|
+#define USB_VID 0xCafe
|
|
|
+#define USB_BCD 0x0200
|
|
|
+
|
|
|
//--------------------------------------------------------------------+
|
|
|
// Device Descriptors
|
|
|
//--------------------------------------------------------------------+
|
|
|
tusb_desc_device_t const desc_device =
|
|
|
{
|
|
|
- .bLength = sizeof(tusb_desc_device_t),
|
|
|
- .bDescriptorType = TUSB_DESC_DEVICE,
|
|
|
- .bcdUSB = 0x0200,
|
|
|
+ .bLength = sizeof(tusb_desc_device_t),
|
|
|
+ .bDescriptorType = TUSB_DESC_DEVICE,
|
|
|
+ .bcdUSB = USB_BCD,
|
|
|
|
|
|
- // Use Interface Association Descriptor (IAD) for CDC
|
|
|
- // As required by USB Specs IAD's subclass must be common class (2) and protocol must be IAD (1)
|
|
|
- .bDeviceClass = TUSB_CLASS_MISC,
|
|
|
- .bDeviceSubClass = MISC_SUBCLASS_COMMON,
|
|
|
- .bDeviceProtocol = MISC_PROTOCOL_IAD,
|
|
|
+ // Use Interface Association Descriptor (IAD) for CDC
|
|
|
+ // As required by USB Specs IAD's subclass must be common class (2) and protocol must be IAD (1)
|
|
|
+ .bDeviceClass = TUSB_CLASS_MISC,
|
|
|
+ .bDeviceSubClass = MISC_SUBCLASS_COMMON,
|
|
|
+ .bDeviceProtocol = MISC_PROTOCOL_IAD,
|
|
|
|
|
|
- .bMaxPacketSize0 = CFG_TUD_ENDPOINT0_SIZE,
|
|
|
+ .bMaxPacketSize0 = CFG_TUD_ENDPOINT0_SIZE,
|
|
|
|
|
|
- .idVendor = 0xCafe,
|
|
|
- .idProduct = USB_PID,
|
|
|
- .bcdDevice = 0x0100,
|
|
|
+ .idVendor = USB_VID,
|
|
|
+ .idProduct = USB_PID,
|
|
|
+ .bcdDevice = 0x0100,
|
|
|
|
|
|
- .iManufacturer = 0x01,
|
|
|
- .iProduct = 0x02,
|
|
|
- .iSerialNumber = 0x03,
|
|
|
+ .iManufacturer = 0x01,
|
|
|
+ .iProduct = 0x02,
|
|
|
+ .iSerialNumber = 0x03,
|
|
|
|
|
|
- .bNumConfigurations = 0x01
|
|
|
+ .bNumConfigurations = 0x01
|
|
|
};
|
|
|
|
|
|
// Invoked when received GET DEVICE DESCRIPTOR
|
|
|
@@ -82,8 +85,6 @@ enum
|
|
|
ITF_NUM_TOTAL
|
|
|
};
|
|
|
|
|
|
-#define CONFIG_TOTAL_LEN (TUD_CONFIG_DESC_LEN + TUD_CDC_DESC_LEN + TUD_MSC_DESC_LEN)
|
|
|
-
|
|
|
#if CFG_TUSB_MCU == OPT_MCU_LPC175X_6X || CFG_TUSB_MCU == OPT_MCU_LPC177X_8X || CFG_TUSB_MCU == OPT_MCU_LPC40XX
|
|
|
// LPC 17xx and 40xx endpoint type (bulk/interrupt/iso) are fixed by its number
|
|
|
// 0 control, 1 In, 2 Bulk, 3 Iso, 4 In, 5 Bulk etc ...
|
|
|
@@ -126,6 +127,9 @@ enum
|
|
|
|
|
|
#endif
|
|
|
|
|
|
+#define CONFIG_TOTAL_LEN (TUD_CONFIG_DESC_LEN + TUD_CDC_DESC_LEN + TUD_MSC_DESC_LEN)
|
|
|
+
|
|
|
+// full speed configuration
|
|
|
uint8_t const desc_fs_configuration[] =
|
|
|
{
|
|
|
// Config number, interface count, string index, total length, attribute, power in mA
|
|
|
@@ -139,6 +143,9 @@ uint8_t const desc_fs_configuration[] =
|
|
|
};
|
|
|
|
|
|
#if TUD_OPT_HIGH_SPEED
|
|
|
+// Per USB specs: high speed capable device must report device_qualifier and other_speed_configuration
|
|
|
+
|
|
|
+// high speed configuration
|
|
|
uint8_t const desc_hs_configuration[] =
|
|
|
{
|
|
|
// Config number, interface count, string index, total length, attribute, power in mA
|
|
|
@@ -150,7 +157,54 @@ uint8_t const desc_hs_configuration[] =
|
|
|
// Interface number, string index, EP Out & EP In address, EP size
|
|
|
TUD_MSC_DESCRIPTOR(ITF_NUM_MSC, 5, EPNUM_MSC_OUT, EPNUM_MSC_IN, 512),
|
|
|
};
|
|
|
-#endif
|
|
|
+
|
|
|
+// other speed configuration
|
|
|
+uint8_t desc_other_speed_config[CONFIG_TOTAL_LEN];
|
|
|
+
|
|
|
+// device qualifier is mostly similar to device descriptor since we don't change configuration based on speed
|
|
|
+tusb_desc_device_qualifier_t const desc_device_qualifier =
|
|
|
+{
|
|
|
+ .bLength = sizeof(tusb_desc_device_qualifier_t),
|
|
|
+ .bDescriptorType = TUSB_DESC_DEVICE_QUALIFIER,
|
|
|
+ .bcdUSB = USB_BCD,
|
|
|
+
|
|
|
+ .bDeviceClass = TUSB_CLASS_MISC,
|
|
|
+ .bDeviceSubClass = MISC_SUBCLASS_COMMON,
|
|
|
+ .bDeviceProtocol = MISC_PROTOCOL_IAD,
|
|
|
+
|
|
|
+ .bMaxPacketSize0 = CFG_TUD_ENDPOINT0_SIZE,
|
|
|
+ .bNumConfigurations = 0x01,
|
|
|
+ .bReserved = 0x00
|
|
|
+};
|
|
|
+
|
|
|
+// Invoked when received GET DEVICE QUALIFIER DESCRIPTOR request
|
|
|
+// Application return pointer to descriptor, whose contents must exist long enough for transfer to complete.
|
|
|
+// device_qualifier descriptor describes information about a high-speed capable device that would
|
|
|
+// change if the device were operating at the other speed. If not highspeed capable stall this request.
|
|
|
+uint8_t const* tud_descriptor_device_qualifier_cb(void)
|
|
|
+{
|
|
|
+ return (uint8_t const*) &desc_device_qualifier;
|
|
|
+}
|
|
|
+
|
|
|
+// Invoked when received GET OTHER SEED CONFIGURATION DESCRIPTOR request
|
|
|
+// Application return pointer to descriptor, whose contents must exist long enough for transfer to complete
|
|
|
+// Configuration descriptor in the other speed e.g if high speed then this is for full speed and vice versa
|
|
|
+uint8_t const* tud_descriptor_other_speed_configuration_cb(uint8_t index)
|
|
|
+{
|
|
|
+ (void) index; // for multiple configurations
|
|
|
+
|
|
|
+ // if link speed is high return fullspeed config, and vice versa
|
|
|
+ // Note: the descriptor type is OHER_SPEED_CONFIG instead of CONFIG
|
|
|
+ memcpy(desc_other_speed_config,
|
|
|
+ (tud_speed_get() == TUSB_SPEED_HIGH) ? desc_fs_configuration : desc_hs_configuration,
|
|
|
+ CONFIG_TOTAL_LEN);
|
|
|
+
|
|
|
+ desc_other_speed_config[1] = TUSB_DESC_OTHER_SPEED_CONFIG;
|
|
|
+
|
|
|
+ return desc_other_speed_config;
|
|
|
+}
|
|
|
+
|
|
|
+#endif // highspeed
|
|
|
|
|
|
|
|
|
// Invoked when received GET CONFIGURATION DESCRIPTOR
|