|
|
@@ -26,19 +26,14 @@
|
|
|
|
|
|
#include "tusb.h"
|
|
|
|
|
|
-// If HID Generic interface is generated
|
|
|
-#define AUTO_DESC_HID_GENERIC (CFG_TUD_HID && ((CFG_TUD_HID_KEYBOARD && !CFG_TUD_HID_KEYBOARD_BOOT) || \
|
|
|
- (CFG_TUD_HID_MOUSE && !CFG_TUD_HID_MOUSE_BOOT)) )
|
|
|
-
|
|
|
/* A combination of interfaces must have a unique product id, since PC will save device driver after the first plug.
|
|
|
* Same VID/PID with different interface e.g MSC (first), then CDC (later) will possibly cause system error on PC.
|
|
|
*
|
|
|
* Auto ProductID layout's Bitmap:
|
|
|
- * [MSB] HID Generic | Boot Mouse | Boot Keyboard | MSC | CDC [LSB]
|
|
|
+ * [MSB] HID | MSC | CDC [LSB]
|
|
|
*/
|
|
|
-#define _PID_MAP(itf, n) ( (CFG_TUD_##itf) << (n) )
|
|
|
-#define CFG_TUD_DESC_PID (0x4000 | _PID_MAP(CDC, 0) | _PID_MAP(MSC, 1) | \
|
|
|
- _PID_MAP(HID_KEYBOARD, 2) | _PID_MAP(HID_MOUSE, 3) | (AUTO_DESC_HID_GENERIC << 4) )
|
|
|
+#define _PID_MAP(itf, n) ( (CFG_TUD_##itf) << (n) )
|
|
|
+#define USB_PID (0x4000 | _PID_MAP(CDC, 0) | _PID_MAP(MSC, 1) | _PID_MAP(HID, 2) )
|
|
|
|
|
|
//------------- Device Descriptors -------------//
|
|
|
tusb_desc_device_t const desc_device =
|
|
|
@@ -62,7 +57,7 @@ tusb_desc_device_t const desc_device =
|
|
|
.bMaxPacketSize0 = CFG_TUD_ENDOINT0_SIZE,
|
|
|
|
|
|
.idVendor = 0xCafe,
|
|
|
- .idProduct = CFG_TUD_DESC_PID,
|
|
|
+ .idProduct = USB_PID,
|
|
|
.bcdDevice = 0x0100,
|
|
|
|
|
|
.iManufacturer = 0x01,
|
|
|
@@ -72,59 +67,105 @@ tusb_desc_device_t const desc_device =
|
|
|
.bNumConfigurations = 0x01
|
|
|
};
|
|
|
|
|
|
-//------------- String Descriptors -------------//
|
|
|
-// array of pointer to string descriptors
|
|
|
-uint16_t const * const string_desc_arr [] =
|
|
|
+//------------- HID Report Descriptor -------------//
|
|
|
+enum
|
|
|
{
|
|
|
- // 0: is supported language = English
|
|
|
- TUD_DESC_STRCONV(0x0409),
|
|
|
+ REPORT_ID_KEYBOARD = 1,
|
|
|
+ REPORT_ID_MOUSE
|
|
|
+};
|
|
|
+
|
|
|
+uint8_t const desc_hid_report[] =
|
|
|
+{
|
|
|
+ HID_REPORT_DESC_KEYBOARD( HID_REPORT_ID(REPORT_ID_KEYBOARD), ),
|
|
|
+ HID_REPORT_DESC_MOUSE ( HID_REPORT_ID(REPORT_ID_MOUSE), )
|
|
|
+};
|
|
|
+
|
|
|
+//------------- Configuration Descriptor -------------//
|
|
|
+enum
|
|
|
+{
|
|
|
+ #if CFG_TUD_CDC
|
|
|
+ ITF_NUM_CDC = 0,
|
|
|
+ ITF_NUM_CDC_DATA,
|
|
|
+ #endif
|
|
|
+
|
|
|
+ #if CFG_TUD_MSC
|
|
|
+ ITF_NUM_MSC,
|
|
|
+ #endif
|
|
|
+
|
|
|
+ #if CFG_TUD_HID
|
|
|
+ ITF_NUM_HID,
|
|
|
+ #endif
|
|
|
+
|
|
|
+ ITF_NUM_TOTAL
|
|
|
+};
|
|
|
|
|
|
- // 1: Manufacturer
|
|
|
- TUD_DESC_STRCONV('t', 'i', 'n', 'y', 'u', 's', 'b', '.', 'o', 'r', 'g'),
|
|
|
+enum
|
|
|
+{
|
|
|
+ CONFIG_DESC_LEN = sizeof(tusb_desc_configuration_t) + CFG_TUD_CDC*TUD_CDC_DESC_LEN + CFG_TUD_MSC*TUD_MSC_DESC_LEN + CFG_TUD_HID*TUD_HID_DESC_LEN
|
|
|
+};
|
|
|
|
|
|
- // 2: Product
|
|
|
- TUD_DESC_STRCONV('t', 'i', 'n', 'y', 'u', 's', 'b', ' ', 'd', 'e', 'v', 'i', 'c', 'e'),
|
|
|
+#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 etc ...
|
|
|
+ // Note: since CDC EP ( 1 & 2), HID (4) are spot-on, thus we only need to force
|
|
|
+ // endpoint number for MSC to 5
|
|
|
+ #define EPNUM_MSC 0x05
|
|
|
+#else
|
|
|
+ #define EPNUM_MSC 0x03
|
|
|
+#endif
|
|
|
|
|
|
- // 3: Serials, should use chip ID
|
|
|
- TUD_DESC_STRCONV('1', '2', '3', '4', '5', '6'),
|
|
|
+uint8_t const desc_configuration[] =
|
|
|
+{
|
|
|
+ // Config: self-powered with remote wakeup support, max power up to 100 mA
|
|
|
+ TUD_CONFIG_DESCRIPTOR(ITF_NUM_TOTAL, 0, CONFIG_DESC_LEN, TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP, 100),
|
|
|
|
|
|
#if CFG_TUD_CDC
|
|
|
- // 4: CDC Interface
|
|
|
- TUD_DESC_STRCONV('t','u','s','b',' ','c','d','c'),
|
|
|
+ TUD_CDC_DESCRIPTOR(ITF_NUM_CDC, 4, 0x81, 8, 0x02, 0x82, 64),
|
|
|
#endif
|
|
|
|
|
|
#if CFG_TUD_MSC
|
|
|
- // 5: MSC Interface
|
|
|
- TUD_DESC_STRCONV('t','u','s','b',' ','m','s','c'),
|
|
|
+ TUD_MSC_DESCRIPTOR(ITF_NUM_MSC, 5, EPNUM_MSC, 0x80 | EPNUM_MSC, 64), // highspeed 512
|
|
|
#endif
|
|
|
|
|
|
-#if CFG_TUD_HID_KEYBOARD
|
|
|
- // 6: Keyboard
|
|
|
- TUD_DESC_STRCONV('t','u','s','b',' ','k','e','y','b','o','a','r','d'),
|
|
|
+#if CFG_TUD_HID
|
|
|
+ TUD_HID_DESCRIPTOR(ITF_NUM_HID, 6, HID_PROTOCOL_KEYBOARD, sizeof(desc_hid_report), 0x84, 16, 10)
|
|
|
#endif
|
|
|
+};
|
|
|
|
|
|
-#if CFG_TUD_HID_MOUSE
|
|
|
- // 7: Mouse
|
|
|
- TUD_DESC_STRCONV('t','u','s','b',' ','m', 'o','u','s','e'),
|
|
|
-#endif
|
|
|
+//------------- String Descriptors -------------//
|
|
|
+// array of pointer to string descriptors
|
|
|
+uint16_t const * const string_desc_arr [] =
|
|
|
+{
|
|
|
+ // 0: is supported language = English
|
|
|
+ TUD_DESC_STRCONV(0x0409),
|
|
|
+
|
|
|
+ // 1: Manufacturer
|
|
|
+ TUD_DESC_STRCONV('t', 'i', 'n', 'y', 'u', 's', 'b', '.', 'o', 'r', 'g'),
|
|
|
+
|
|
|
+ // 2: Product
|
|
|
+ TUD_DESC_STRCONV('t', 'i', 'n', 'y', 'u', 's', 'b', ' ', 'd', 'e', 'v', 'i', 'c', 'e'),
|
|
|
|
|
|
+ // 3: Serials, should use chip ID
|
|
|
+ TUD_DESC_STRCONV('1', '2', '3', '4', '5', '6'),
|
|
|
+
|
|
|
+ // 4: CDC Interface
|
|
|
+ TUD_DESC_STRCONV('t','u','s','b',' ','c','d','c'),
|
|
|
+
|
|
|
+ // 5: MSC Interface
|
|
|
+ TUD_DESC_STRCONV('t','u','s','b',' ','m','s','c'),
|
|
|
+
|
|
|
+ // 6: HID
|
|
|
+ TUD_DESC_STRCONV('t','u','s','b',' ','h','i','d')
|
|
|
};
|
|
|
|
|
|
// tud_desc_set is required by tinyusb stack
|
|
|
-// since CFG_TUD_DESC_AUTO is enabled, we only need to set string_arr
|
|
|
tud_desc_set_t tud_desc_set =
|
|
|
{
|
|
|
.device = &desc_device,
|
|
|
- .config = NULL,
|
|
|
+ .config = desc_configuration,
|
|
|
|
|
|
.string_arr = (uint8_t const **) string_desc_arr,
|
|
|
.string_count = sizeof(string_desc_arr)/sizeof(string_desc_arr[0]),
|
|
|
|
|
|
- .hid_report =
|
|
|
- {
|
|
|
- .generic = NULL,
|
|
|
- .boot_keyboard = NULL,
|
|
|
- .boot_mouse = NULL
|
|
|
- }
|
|
|
+ .hid_report = desc_hid_report,
|
|
|
};
|
|
|
-
|