47 const usb_config_desc_t *config_desc;
48 const usb_device_desc_t *device_desc;
49 int conf_offset = 0, ep_offset;
50 std::vector<CdcEps> cdc_devs{};
53 if (usb_host_get_device_descriptor(dev_hdl, &device_desc) != ESP_OK) {
54 ESP_LOGE(TAG,
"get_device_descriptor failed");
57 if (usb_host_get_active_config_descriptor(dev_hdl, &config_desc) != ESP_OK) {
58 ESP_LOGE(TAG,
"get_active_config_descriptor failed");
62 "bDeviceClass: %u, bDeviceSubClass: %u\n"
64 device_desc->bDeviceClass, device_desc->bDeviceSubClass, config_desc->bNumInterfaces);
65 if (device_desc->bDeviceClass != 0) {
66 ESP_LOGE(TAG,
"bDeviceClass != 0");
70 for (uint8_t i = 0; i != config_desc->bNumInterfaces; i++) {
71 auto data_desc = usb_parse_interface_descriptor(config_desc, 0, 0, &conf_offset);
73 ESP_LOGE(TAG,
"data_desc: usb_parse_interface_descriptor failed");
76 if (data_desc->bNumEndpoints != 2 || data_desc->bInterfaceClass != USB_CLASS_VENDOR_SPEC) {
77 ESP_LOGE(TAG,
"data_desc: bInterfaceClass == %u, bInterfaceSubClass == %u, bNumEndpoints == %u",
78 data_desc->bInterfaceClass, data_desc->bInterfaceSubClass, data_desc->bNumEndpoints);
81 ep_offset = conf_offset;
82 auto out_ep = usb_parse_endpoint_descriptor_by_index(data_desc, 0, config_desc->wTotalLength, &ep_offset);
84 ESP_LOGE(TAG,
"out_ep: usb_parse_endpoint_descriptor_by_index failed");
87 ep_offset = conf_offset;
88 auto in_ep = usb_parse_endpoint_descriptor_by_index(data_desc, 1, config_desc->wTotalLength, &ep_offset);
90 ESP_LOGE(TAG,
"in_ep: usb_parse_endpoint_descriptor_by_index failed");
93 if (in_ep->bEndpointAddress & usb_host::USB_DIR_IN) {
94 cdc_devs.push_back({
CdcEps{
nullptr, in_ep, out_ep, data_desc->bInterfaceNumber}});
96 cdc_devs.push_back({
CdcEps{
nullptr, out_ep, in_ep, data_desc->bInterfaceNumber}});
105 if (!channel->initialised_.load())
109 ESP_LOGE(TAG,
"Control transfer failed, status=%s", esp_err_to_name(
status.error_code));
110 channel->initialised_.store(
false);
113 this->
control_transfer(USB_VENDOR_IFC | usb_host::USB_DIR_OUT, IFC_ENABLE, 1, channel->index_, callback);
114 uint16_t line_control = channel->stop_bits_;
115 line_control |=
static_cast<uint8_t
>(channel->parity_) << 4;
116 line_control |= channel->data_bits_ << 8;
117 ESP_LOGD(TAG,
"Line control value 0x%X", line_control);
118 this->
control_transfer(USB_VENDOR_IFC | usb_host::USB_DIR_OUT, SET_LINE_CTL, line_control, channel->index_,
121 this->
control_transfer(USB_VENDOR_IFC | usb_host::USB_DIR_OUT, SET_BAUDRATE, 0, channel->index_, callback,