Merge pull request #497 from hathach/improve-midi

Improve midi
This commit is contained in:
Ha Thach 2020-08-27 18:45:22 +07:00 committed by GitHub
commit f10b8145af
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 36 additions and 27 deletions

View File

@ -164,7 +164,7 @@ uint32_t tud_cdc_n_write_flush (uint8_t itf)
// skip if previous transfer not complete yet // skip if previous transfer not complete yet
TU_VERIFY( !usbd_edpt_busy(TUD_OPT_RHPORT, p_cdc->ep_in), 0 ); TU_VERIFY( !usbd_edpt_busy(TUD_OPT_RHPORT, p_cdc->ep_in), 0 );
uint16_t count = tu_fifo_read_n(&_cdcd_itf[itf].tx_ff, p_cdc->epin_buf, sizeof(p_cdc->epin_buf)); uint16_t count = tu_fifo_read_n(&p_cdc->tx_ff, p_cdc->epin_buf, sizeof(p_cdc->epin_buf));
if ( count ) if ( count )
{ {
TU_VERIFY( tud_cdc_n_connected(itf), 0 ); // fifo is empty if not connected TU_VERIFY( tud_cdc_n_connected(itf), 0 ); // fifo is empty if not connected
@ -376,7 +376,6 @@ bool cdcd_control_request(uint8_t rhport, tusb_control_request_t const * request
bool cdcd_xfer_cb(uint8_t rhport, uint8_t ep_addr, xfer_result_t result, uint32_t xferred_bytes) bool cdcd_xfer_cb(uint8_t rhport, uint8_t ep_addr, xfer_result_t result, uint32_t xferred_bytes)
{ {
(void) rhport;
(void) result; (void) result;
uint8_t itf; uint8_t itf;
@ -393,6 +392,7 @@ bool cdcd_xfer_cb(uint8_t rhport, uint8_t ep_addr, xfer_result_t result, uint32_
// Received new data // Received new data
if ( ep_addr == p_cdc->ep_out ) if ( ep_addr == p_cdc->ep_out )
{ {
// TODO search for wanted char first for better performance
for(uint32_t i=0; i<xferred_bytes; i++) for(uint32_t i=0; i<xferred_bytes; i++)
{ {
tu_fifo_write(&p_cdc->rx_ff, &p_cdc->epout_buf[i]); tu_fifo_write(&p_cdc->rx_ff, &p_cdc->epout_buf[i]);
@ -423,9 +423,10 @@ bool cdcd_xfer_cb(uint8_t rhport, uint8_t ep_addr, xfer_result_t result, uint32_
{ {
// There is no data left, a ZLP should be sent if // There is no data left, a ZLP should be sent if
// xferred_bytes is multiple of EP size and not zero // xferred_bytes is multiple of EP size and not zero
// FIXME CFG_TUD_CDC_EP_BUFSIZE is not Endpoint packet size
if ( xferred_bytes && (0 == (xferred_bytes % CFG_TUD_CDC_EP_BUFSIZE)) ) if ( xferred_bytes && (0 == (xferred_bytes % CFG_TUD_CDC_EP_BUFSIZE)) )
{ {
usbd_edpt_xfer(TUD_OPT_RHPORT, p_cdc->ep_in, NULL, 0); usbd_edpt_xfer(rhport, p_cdc->ep_in, NULL, 0);
} }
} }
} }

View File

@ -57,7 +57,6 @@
// CFG_TUD_CDC > 1 // CFG_TUD_CDC > 1
//--------------------------------------------------------------------+ //--------------------------------------------------------------------+
// Check if terminal is connected to this port // Check if terminal is connected to this port
bool tud_cdc_n_connected (uint8_t itf); bool tud_cdc_n_connected (uint8_t itf);

View File

@ -101,8 +101,7 @@ uint32_t tud_midi_n_read(uint8_t itf, uint8_t jack_id, void* buffer, uint32_t bu
// Fill empty buffer // Fill empty buffer
if (midi->read_buffer_length == 0) { if (midi->read_buffer_length == 0) {
if (!tud_midi_n_receive(itf, midi->read_buffer)) if (!tud_midi_n_receive(itf, midi->read_buffer)) return 0;
return 0;
uint8_t code_index = midi->read_buffer[0] & 0x0f; uint8_t code_index = midi->read_buffer[0] & 0x0f;
// We always copy over the first byte. // We always copy over the first byte.
@ -119,8 +118,7 @@ uint32_t tud_midi_n_read(uint8_t itf, uint8_t jack_id, void* buffer, uint32_t bu
} }
uint32_t n = midi->read_buffer_length - midi->read_target_length; uint32_t n = midi->read_buffer_length - midi->read_target_length;
if (bufsize < n) if (bufsize < n) n = bufsize;
n = bufsize;
// Skip the header in the buffer // Skip the header in the buffer
memcpy(buffer, midi->read_buffer + 1 + midi->read_target_length, n); memcpy(buffer, midi->read_buffer + 1 + midi->read_target_length, n);
@ -153,10 +151,8 @@ void midi_rx_done_cb(midid_interface_t* midi, uint8_t const* buffer, uint32_t bu
// WRITE API // WRITE API
//--------------------------------------------------------------------+ //--------------------------------------------------------------------+
static bool maybe_transmit(midid_interface_t* midi, uint8_t itf_index) static uint32_t write_flush(midid_interface_t* midi)
{ {
(void) itf_index;
// skip if previous transfer not complete // skip if previous transfer not complete
TU_VERIFY( !usbd_edpt_busy(TUD_OPT_RHPORT, midi->ep_in) ); TU_VERIFY( !usbd_edpt_busy(TUD_OPT_RHPORT, midi->ep_in) );
@ -165,7 +161,7 @@ static bool maybe_transmit(midid_interface_t* midi, uint8_t itf_index)
{ {
TU_ASSERT( usbd_edpt_xfer(TUD_OPT_RHPORT, midi->ep_in, midi->epin_buf, count) ); TU_ASSERT( usbd_edpt_xfer(TUD_OPT_RHPORT, midi->ep_in, midi->epin_buf, count) );
} }
return true; return count;
} }
uint32_t tud_midi_n_write(uint8_t itf, uint8_t jack_id, uint8_t const* buffer, uint32_t bufsize) uint32_t tud_midi_n_write(uint8_t itf, uint8_t jack_id, uint8_t const* buffer, uint32_t bufsize)
@ -234,7 +230,8 @@ uint32_t tud_midi_n_write(uint8_t itf, uint8_t jack_id, uint8_t const* buffer, u
} }
i++; i++;
} }
maybe_transmit(midi, itf);
write_flush(midi);
return i; return i;
} }
@ -250,7 +247,7 @@ bool tud_midi_n_send (uint8_t itf, uint8_t const packet[4])
return false; return false;
tu_fifo_write_n(&midi->tx_ff, packet, 4); tu_fifo_write_n(&midi->tx_ff, packet, 4);
maybe_transmit(midi, itf); write_flush(midi);
return true; return true;
} }
@ -388,28 +385,40 @@ bool midid_xfer_cb(uint8_t rhport, uint8_t ep_addr, xfer_result_t result, uint32
{ {
(void) result; (void) result;
uint8_t itf = 0; uint8_t itf;
midid_interface_t* p_midi = _midid_itf; midid_interface_t* p_midi;
for ( ; ; itf++, p_midi++) // Identify which interface to use
for (itf = 0; itf < CFG_TUD_MIDI; itf++)
{ {
if (itf >= TU_ARRAY_SIZE(_midid_itf)) return false; p_midi = &_midid_itf[itf];
if ( ( ep_addr == p_midi->ep_out ) || ( ep_addr == p_midi->ep_in ) ) break;
if ( ep_addr == p_midi->ep_out ) break;
} }
TU_ASSERT(itf < CFG_TUD_MIDI);
// receive new data // receive new data
if ( ep_addr == p_midi->ep_out ) if ( ep_addr == p_midi->ep_out )
{ {
midi_rx_done_cb(p_midi, p_midi->epout_buf, xferred_bytes); tu_fifo_write_n(&p_midi->rx_ff, p_midi->epout_buf, xferred_bytes);
// invoke receive callback if available
if (tud_midi_rx_cb) tud_midi_rx_cb(itf);
// prepare for next // prepare for next
TU_ASSERT( usbd_edpt_xfer(rhport, p_midi->ep_out, p_midi->epout_buf, CFG_TUD_MIDI_EP_BUFSIZE), false ); TU_ASSERT(usbd_edpt_xfer(rhport, p_midi->ep_out, p_midi->epout_buf, CFG_TUD_MIDI_EP_BUFSIZE), false);
} else if ( ep_addr == p_midi->ep_in ) { }
maybe_transmit(p_midi, itf); else if ( ep_addr == p_midi->ep_in )
{
if (0 == write_flush(p_midi))
{
// There is no data left, a ZLP should be sent if
// xferred_bytes is multiple of EP size and not zero
if ( xferred_bytes && (0 == (xferred_bytes % CFG_TUD_MIDI_EP_BUFSIZE)) )
{
usbd_edpt_xfer(rhport, p_midi->ep_in, NULL, 0);
}
}
} }
// nothing to do with in and notif endpoint
return true; return true;
} }

View File

@ -72,7 +72,7 @@ bool tud_midi_n_receive (uint8_t itf, uint8_t packet[4]);
bool tud_midi_n_send (uint8_t itf, uint8_t const packet[4]); bool tud_midi_n_send (uint8_t itf, uint8_t const packet[4]);
//--------------------------------------------------------------------+ //--------------------------------------------------------------------+
// Application API (Interface0) // Application API (Single Interface)
//--------------------------------------------------------------------+ //--------------------------------------------------------------------+
static inline bool tud_midi_mounted (void); static inline bool tud_midi_mounted (void);
static inline uint32_t tud_midi_available (void); static inline uint32_t tud_midi_available (void);