mirror of
https://github.com/hathach/tinyusb.git
synced 2025-01-31 05:52:55 +08:00
fix stall response with SET_INTERFACE/GET_INTERFACE
webusb work with linux & macos
This commit is contained in:
parent
4ed1a96311
commit
cdaf455461
@ -86,6 +86,28 @@ int main(void)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// send characters to both CDC and WebUSB
|
||||||
|
void echo_all(uint8_t buf[], uint32_t count)
|
||||||
|
{
|
||||||
|
// echo to web serial
|
||||||
|
if ( web_serial_connected )
|
||||||
|
{
|
||||||
|
tud_vendor_write(buf, count);
|
||||||
|
}
|
||||||
|
|
||||||
|
// echo to cdc
|
||||||
|
if ( tud_cdc_connected() )
|
||||||
|
{
|
||||||
|
for(uint32_t i=0; i<count; i++)
|
||||||
|
{
|
||||||
|
tud_cdc_write_char(buf[i]);
|
||||||
|
|
||||||
|
if ( buf[i] == '\r' ) tud_cdc_write_char('\n');
|
||||||
|
}
|
||||||
|
tud_cdc_write_flush();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
// Device callbacks
|
// Device callbacks
|
||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
@ -117,28 +139,6 @@ void tud_resume_cb(void)
|
|||||||
blink_interval_ms = BLINK_MOUNTED;
|
blink_interval_ms = BLINK_MOUNTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
// send characters to both CDC and WebUSB
|
|
||||||
void echo_all(uint8_t buf[], uint32_t count)
|
|
||||||
{
|
|
||||||
// echo to web serial
|
|
||||||
if ( web_serial_connected )
|
|
||||||
{
|
|
||||||
tud_vendor_write(buf, count);
|
|
||||||
}
|
|
||||||
|
|
||||||
// echo to cdc
|
|
||||||
if ( tud_cdc_connected() )
|
|
||||||
{
|
|
||||||
for(uint32_t i=0; i<count; i++)
|
|
||||||
{
|
|
||||||
tud_cdc_write_char(buf[i]);
|
|
||||||
|
|
||||||
if ( buf[i] == '\r' ) tud_cdc_write_char('\n');
|
|
||||||
}
|
|
||||||
tud_cdc_write_flush();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
// WebUSB use vendor class
|
// WebUSB use vendor class
|
||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
|
@ -439,10 +439,34 @@ static bool process_control_request(uint8_t rhport, tusb_control_request_t const
|
|||||||
|
|
||||||
TU_VERIFY(drvid < USBD_CLASS_DRIVER_COUNT);
|
TU_VERIFY(drvid < USBD_CLASS_DRIVER_COUNT);
|
||||||
|
|
||||||
usbd_control_set_complete_callback(usbd_class_drivers[drvid].control_complete);
|
switch ( p_request->bRequest )
|
||||||
|
{
|
||||||
|
case TUSB_REQ_GET_INTERFACE:
|
||||||
|
{
|
||||||
|
// TODO not support alternate interface yet
|
||||||
|
uint8_t alternate = 0;
|
||||||
|
tud_control_xfer(rhport, p_request, &alternate, 1);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
// stall control endpoint if driver return false
|
case TUSB_REQ_SET_INTERFACE:
|
||||||
return usbd_class_drivers[drvid].control_request(rhport, p_request);
|
{
|
||||||
|
uint8_t alternate = (uint8_t) p_request->wValue;
|
||||||
|
|
||||||
|
// TODO not support alternate interface yet
|
||||||
|
TU_ASSERT(alternate == 0);
|
||||||
|
|
||||||
|
tud_control_status(rhport, p_request);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
// forward to class driver
|
||||||
|
// stall control endpoint if driver return false
|
||||||
|
usbd_control_set_complete_callback(usbd_class_drivers[drvid].control_complete);
|
||||||
|
TU_ASSERT(usbd_class_drivers[drvid].control_request(rhport, p_request));
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user