mirror of
https://github.com/hathach/tinyusb.git
synced 2025-03-23 13:20:54 +00:00
correct cdc host app
This commit is contained in:
parent
22b62f8712
commit
badb30a6c3
@ -52,26 +52,31 @@ size_t get_console_inputs(uint8_t* buf, size_t bufsize)
|
|||||||
void cdc_app_task(void)
|
void cdc_app_task(void)
|
||||||
{
|
{
|
||||||
uint8_t buf[64+1]; // +1 for extra null character
|
uint8_t buf[64+1]; // +1 for extra null character
|
||||||
memset(buf, 0, sizeof(buf));
|
uint32_t const bufsize = sizeof(buf)-1;
|
||||||
|
|
||||||
size_t count = get_console_inputs(buf, sizeof(buf)-1);
|
uint32_t console_count = get_console_inputs(buf, bufsize);
|
||||||
|
buf[console_count] = 0;
|
||||||
|
|
||||||
// loop over all mounted interfaces
|
// loop over all mounted interfaces
|
||||||
for(size_t idx=0; idx<CFG_TUH_CDC; idx++)
|
for(uint8_t idx=0; idx<CFG_TUH_CDC; idx++)
|
||||||
{
|
{
|
||||||
if ( tuh_cdc_mounted(idx) )
|
if ( tuh_cdc_mounted(idx) )
|
||||||
{
|
{
|
||||||
// console --> cdc interfaces
|
// console --> cdc interfaces
|
||||||
if (count)
|
if (console_count)
|
||||||
{
|
{
|
||||||
tuh_cdc_write(idx, buf, count);
|
tuh_cdc_write(idx, buf, console_count);
|
||||||
tuh_cdc_write_flush(idx);
|
tuh_cdc_write_flush(idx);
|
||||||
}
|
}
|
||||||
|
|
||||||
// cdc interfaces -> console
|
// cdc interfaces -> console
|
||||||
if ( tuh_cdc_read_available(idx) )
|
if ( tuh_cdc_read_available(idx) )
|
||||||
{
|
{
|
||||||
printf((char*) buf);
|
uint8_t buf_cdc[64+1];
|
||||||
|
uint32_t cdc_count = tuh_cdc_read(idx, buf_cdc, sizeof(buf_cdc)-1);
|
||||||
|
buf_cdc[cdc_count] = 0;
|
||||||
|
|
||||||
|
printf((char*) buf_cdc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -459,7 +459,8 @@ bool cdch_xfer_cb(uint8_t daddr, uint8_t ep_addr, xfer_result_t event, uint32_t
|
|||||||
}
|
}
|
||||||
else if ( ep_addr == p_cdc->stream.rx.ep_addr )
|
else if ( ep_addr == p_cdc->stream.rx.ep_addr )
|
||||||
{
|
{
|
||||||
tu_edpt_stream_read_xfer_complete(&p_cdc->stream.rx, xferred_bytes);
|
// skip if ZLP
|
||||||
|
if (xferred_bytes) tu_edpt_stream_read_xfer_complete(&p_cdc->stream.rx, xferred_bytes);
|
||||||
|
|
||||||
// invoke receive callback
|
// invoke receive callback
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user