add xferred bytes for device control

This commit is contained in:
hathach 2018-05-15 22:06:49 +07:00
parent 1d428b7fef
commit d96abdb0ad
3 changed files with 6 additions and 6 deletions

View File

@ -76,10 +76,10 @@ void dcd_bus_event (uint8_t rhport, usbd_bus_event_type_t bus_event);
void dcd_setup_received (uint8_t rhport, uint8_t const* p_request);
void dcd_xfer_complete (uint8_t rhport, uint8_t ep_addr, uint32_t xferred_bytes, bool succeeded);
static inline void dcd_control_complete(uint8_t rhport)
static inline void dcd_control_complete(uint8_t rhport, uint32_t xferred_bytes)
{
// all control complete is successful !!
dcd_xfer_complete(rhport, 0, 0, true);
dcd_xfer_complete(rhport, 0, xferred_bytes, true);
}
/*------------------------------------------------------------------*/

View File

@ -556,12 +556,12 @@ void dcd_xfer_complete(uint8_t rhport, uint8_t ep_addr, uint32_t xferred_bytes,
{
if (ep_addr == 0 )
{
// Control Transfer
(void) rhport;
(void) xferred_bytes;
(void) succeeded;
// Control Transfer
osal_semaphore_post( _usbd_ctrl_sem );
// only signal data stage, skip status (zero byte)
if (xferred_bytes) osal_semaphore_post( _usbd_ctrl_sem );
}else
{
usbd_task_event_t task_event =

View File

@ -475,7 +475,7 @@ void hal_dcd_isr(uint8_t rhport)
bool succeeded = ( p_qtd->xact_err || p_qtd->halted || p_qtd->buffer_err ) ? false : true;
(void) succeeded;
dcd_control_complete(rhport);
dcd_control_complete(rhport, p_qtd->expected_bytes - p_qtd->total_bytes);
}
}