usb_descriptors.c 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. /*
  2. * The MIT License (MIT)
  3. *
  4. * Copyright (c) 2020 Ha Thach (tinyusb.org)
  5. * Copyright (c) 2020 Jerzy Kasenberg
  6. *
  7. * Permission is hereby granted, free of charge, to any person obtaining a copy
  8. * of this software and associated documentation files (the "Software"), to deal
  9. * in the Software without restriction, including without limitation the rights
  10. * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  11. * copies of the Software, and to permit persons to whom the Software is
  12. * furnished to do so, subject to the following conditions:
  13. *
  14. * The above copyright notice and this permission notice shall be included in
  15. * all copies or substantial portions of the Software.
  16. *
  17. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  18. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  19. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  20. * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  21. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  22. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  23. * THE SOFTWARE.
  24. *
  25. */
  26. #include "tusb.h"
  27. #include "usb_descriptors.h"
  28. /* A combination of interfaces must have a unique product id, since PC will save device driver after the first plug.
  29. * Same VID/PID with different interface e.g MSC (first), then CDC (later) will possibly cause system error on PC.
  30. *
  31. * Auto ProductID layout's Bitmap:
  32. * [MSB] AUDIO | MIDI | HID | MSC | CDC [LSB]
  33. */
  34. #define _PID_MAP(itf, n) ( (CFG_TUD_##itf) << (n) )
  35. #define USB_PID (0x4000 | _PID_MAP(CDC, 0) | _PID_MAP(MSC, 1) | _PID_MAP(HID, 2) | \
  36. _PID_MAP(MIDI, 3) | _PID_MAP(AUDIO, 4) | _PID_MAP(VENDOR, 5) )
  37. //--------------------------------------------------------------------+
  38. // Device Descriptors
  39. //--------------------------------------------------------------------+
  40. tusb_desc_device_t const desc_device =
  41. {
  42. .bLength = sizeof(tusb_desc_device_t),
  43. .bDescriptorType = TUSB_DESC_DEVICE,
  44. .bcdUSB = 0x0200,
  45. // Use Interface Association Descriptor (IAD) for CDC
  46. // As required by USB Specs IAD's subclass must be common class (2) and protocol must be IAD (1)
  47. .bDeviceClass = TUSB_CLASS_MISC,
  48. .bDeviceSubClass = MISC_SUBCLASS_COMMON,
  49. .bDeviceProtocol = MISC_PROTOCOL_IAD,
  50. .bMaxPacketSize0 = CFG_TUD_ENDPOINT0_SIZE,
  51. .idVendor = 0xCafe,
  52. .idProduct = USB_PID,
  53. .bcdDevice = 0x0100,
  54. .iManufacturer = 0x01,
  55. .iProduct = 0x02,
  56. .iSerialNumber = 0x03,
  57. .bNumConfigurations = 0x01
  58. };
  59. // Invoked when received GET DEVICE DESCRIPTOR
  60. // Application return pointer to descriptor
  61. uint8_t const * tud_descriptor_device_cb(void)
  62. {
  63. return (uint8_t const *)&desc_device;
  64. }
  65. //--------------------------------------------------------------------+
  66. // Configuration Descriptor
  67. //--------------------------------------------------------------------+
  68. #define CONFIG_TOTAL_LEN (TUD_CONFIG_DESC_LEN + CFG_TUD_AUDIO * TUD_AUDIO_HEADSET_STEREO_DESC_LEN)
  69. #if CFG_TUSB_MCU == OPT_MCU_LPC175X_6X || CFG_TUSB_MCU == OPT_MCU_LPC177X_8X || CFG_TUSB_MCU == OPT_MCU_LPC40XX
  70. // LPC 17xx and 40xx endpoint type (bulk/interrupt/iso) are fixed by its number
  71. // 0 control, 1 In, 2 Bulk, 3 Iso, 4 In etc ...
  72. #define EPNUM_AUDIO_IN 0x03
  73. #define EPNUM_AUDIO_OUT 0x03
  74. #elif CFG_TUSB_MCU == OPT_MCU_NRF5X
  75. // ISO endpoints for NRF5x are fixed to 0x08 (0x88)
  76. #define EPNUM_AUDIO_IN 0x08
  77. #define EPNUM_AUDIO_OUT 0x08
  78. #elif CFG_TUSB_MCU == OPT_MCU_SAMG || CFG_TUSB_MCU == OPT_MCU_SAMX7X
  79. // SAMG & SAME70 don't support a same endpoint number with different direction IN and OUT
  80. // e.g EP1 OUT & EP1 IN cannot exist together
  81. #define EPNUM_AUDIO_IN 0x01
  82. #define EPNUM_AUDIO_OUT 0x02
  83. #else
  84. #define EPNUM_AUDIO_IN 0x01
  85. #define EPNUM_AUDIO_OUT 0x01
  86. #endif
  87. uint8_t const desc_configuration[] =
  88. {
  89. // Interface count, string index, total length, attribute, power in mA
  90. TUD_CONFIG_DESCRIPTOR(1, ITF_NUM_TOTAL, 0, CONFIG_TOTAL_LEN, 0x00, 100),
  91. // Interface number, string index, EP Out & EP In address, EP size
  92. TUD_AUDIO_HEADSET_STEREO_DESCRIPTOR(2, EPNUM_AUDIO_OUT, EPNUM_AUDIO_IN | 0x80)
  93. };
  94. // Invoked when received GET CONFIGURATION DESCRIPTOR
  95. // Application return pointer to descriptor
  96. // Descriptor contents must exist long enough for transfer to complete
  97. uint8_t const * tud_descriptor_configuration_cb(uint8_t index)
  98. {
  99. (void)index; // for multiple configurations
  100. return desc_configuration;
  101. }
  102. //--------------------------------------------------------------------+
  103. // String Descriptors
  104. //--------------------------------------------------------------------+
  105. // array of pointer to string descriptors
  106. char const* string_desc_arr [] =
  107. {
  108. (const char[]) { 0x09, 0x04 }, // 0: is supported language is English (0x0409)
  109. "TinyUSB", // 1: Manufacturer
  110. "TinyUSB headset", // 2: Product
  111. "000001", // 3: Serials, should use chip ID
  112. "TinyUSB Speakers", // 4: Audio Interface
  113. "TinyUSB Microphone", // 5: Audio Interface
  114. };
  115. static uint16_t _desc_str[32];
  116. // Invoked when received GET STRING DESCRIPTOR request
  117. // Application return pointer to descriptor, whose contents must exist long enough for transfer to complete
  118. uint16_t const* tud_descriptor_string_cb(uint8_t index, uint16_t langid)
  119. {
  120. (void)langid;
  121. uint8_t chr_count;
  122. if (index == 0)
  123. {
  124. memcpy(&_desc_str[1], string_desc_arr[0], 2);
  125. chr_count = 1;
  126. }
  127. else
  128. {
  129. // Convert ASCII string into UTF-16
  130. if (!(index < sizeof(string_desc_arr)/sizeof(string_desc_arr[0]))) return NULL;
  131. const char* str = string_desc_arr[index];
  132. // Cap at max char
  133. chr_count = strlen(str);
  134. if (chr_count > 31) chr_count = 31;
  135. for (uint8_t i = 0; i < chr_count; i++)
  136. {
  137. _desc_str[1 + i] = str[i];
  138. }
  139. }
  140. // first byte is length (including header), second byte is string type
  141. _desc_str[0] = (TUSB_DESC_STRING << 8 ) | (2 * chr_count + 2);
  142. return _desc_str;
  143. }