more dcd clean up

This commit is contained in:
hathach 2018-03-28 13:54:28 +07:00
parent 4deb4da6cb
commit 47c125d025
6 changed files with 34 additions and 32 deletions

View File

@ -258,11 +258,11 @@ tusb_error_t cdcd_control_request_st(uint8_t rhport, tusb_control_request_t cons
p_cdc->connected = false; p_cdc->connected = false;
} }
usbd_control_status(rhport, p_request->bmRequestType_bit.direction); dcd_control_status(rhport, p_request->bmRequestType_bit.direction);
} }
else else
{ {
usbd_control_stall(rhport); // stall unsupported request dcd_control_stall(rhport); // stall unsupported request
} }
OSAL_SUBTASK_END OSAL_SUBTASK_END

View File

@ -212,7 +212,7 @@ tusb_error_t hidd_control_request_st(uint8_t rhport, tusb_control_request_t cons
STASK_INVOKE( usbd_control_xfer_st(rhport, p_request->bmRequestType_bit.direction, m_hid_buffer, p_hid->report_length), err ); STASK_INVOKE( usbd_control_xfer_st(rhport, p_request->bmRequestType_bit.direction, m_hid_buffer, p_hid->report_length), err );
}else }else
{ {
usbd_control_stall(rhport); dcd_control_stall(rhport);
} }
} }
//------------- Class Specific Request -------------// //------------- Class Specific Request -------------//
@ -241,17 +241,17 @@ tusb_error_t hidd_control_request_st(uint8_t rhport, tusb_control_request_t cons
else if (HID_REQUEST_CONTROL_SET_IDLE == p_request->bRequest) else if (HID_REQUEST_CONTROL_SET_IDLE == p_request->bRequest)
{ {
// uint8_t idle_rate = u16_high_u8(p_request->wValue); // uint8_t idle_rate = u16_high_u8(p_request->wValue);
usbd_control_status(rhport, p_request->bmRequestType_bit.direction); dcd_control_status(rhport, p_request->bmRequestType_bit.direction);
}else }else
{ {
// HID_REQUEST_CONTROL_GET_IDLE: // HID_REQUEST_CONTROL_GET_IDLE:
// HID_REQUEST_CONTROL_GET_PROTOCOL: // HID_REQUEST_CONTROL_GET_PROTOCOL:
// HID_REQUEST_CONTROL_SET_PROTOCOL: // HID_REQUEST_CONTROL_SET_PROTOCOL:
usbd_control_stall(rhport); dcd_control_stall(rhport);
} }
}else }else
{ {
usbd_control_stall(rhport); dcd_control_stall(rhport);
} }
OSAL_SUBTASK_END OSAL_SUBTASK_END

View File

@ -147,7 +147,7 @@ tusb_error_t mscd_control_request_st(uint8_t rhport, tusb_control_request_t cons
if(MSC_REQUEST_RESET == p_request->bRequest) if(MSC_REQUEST_RESET == p_request->bRequest)
{ {
usbd_control_status(rhport, p_request->bmRequestType_bit.direction); dcd_control_status(rhport, p_request->bmRequestType_bit.direction);
} }
else if (MSC_REQUEST_GET_MAX_LUN == p_request->bRequest) else if (MSC_REQUEST_GET_MAX_LUN == p_request->bRequest)
{ {
@ -156,7 +156,7 @@ tusb_error_t mscd_control_request_st(uint8_t rhport, tusb_control_request_t cons
STASK_INVOKE( usbd_control_xfer_st(rhport, p_request->bmRequestType_bit.direction, p_msc->scsi_data, 1), err); STASK_INVOKE( usbd_control_xfer_st(rhport, p_request->bmRequestType_bit.direction, p_msc->scsi_data, 1), err);
}else }else
{ {
usbd_control_stall(rhport); // stall unsupported request dcd_control_stall(rhport); // stall unsupported request
} }
OSAL_SUBTASK_END OSAL_SUBTASK_END

View File

@ -77,17 +77,15 @@ void dcd_xfer_complete (uint8_t rhport, uint8_t ep_addr, uint32_t xferred_byt
static inline void dcd_control_complete(uint8_t rhport) static inline void dcd_control_complete(uint8_t rhport)
{ {
// TODO all control complete is successful !! // all control complete is successful !!
dcd_xfer_complete(rhport, 0, 0, true); dcd_xfer_complete(rhport, 0, 0, true);
} }
/*------------------------------------------------------------------*/ /*------------------------------------------------------------------*/
/* Endpoint API /* Endpoint API
*------------------------------------------------------------------*/ *------------------------------------------------------------------*/
//------------- Control Endpoint -------------//
bool dcd_control_xfer (uint8_t rhport, tusb_dir_t dir, uint8_t * buffer, uint16_t length);
//------------- Other Endpoints -------------// //------------- Non-control Endpoints -------------//
bool dcd_edpt_open (uint8_t rhport, tusb_desc_endpoint_t const * p_endpoint_desc); bool dcd_edpt_open (uint8_t rhport, tusb_desc_endpoint_t const * p_endpoint_desc);
bool dcd_edpt_xfer (uint8_t rhport, uint8_t ep_addr, uint8_t * buffer, uint16_t total_bytes); bool dcd_edpt_xfer (uint8_t rhport, uint8_t ep_addr, uint8_t * buffer, uint16_t total_bytes);
bool dcd_edpt_busy (uint8_t rhport, uint8_t ep_addr); bool dcd_edpt_busy (uint8_t rhport, uint8_t ep_addr);
@ -95,6 +93,21 @@ bool dcd_edpt_busy (uint8_t rhport, uint8_t ep_addr);
void dcd_edpt_stall (uint8_t rhport, uint8_t ep_addr); void dcd_edpt_stall (uint8_t rhport, uint8_t ep_addr);
void dcd_edpt_clear_stall (uint8_t rhport, uint8_t ep_addr); void dcd_edpt_clear_stall (uint8_t rhport, uint8_t ep_addr);
//------------- Control Endpoint -------------//
bool dcd_control_xfer (uint8_t rhport, tusb_dir_t dir, uint8_t * buffer, uint16_t length);
// Note input dir is value of direction bit in setup packet (i.e DATA stage direction)
static inline bool dcd_control_status(uint8_t rhport, tusb_dir_t dir)
{
// status direction is reversed to one in the setup packet
return dcd_control_xfer(rhport, 1-dir, NULL, 0);
}
static inline void dcd_control_stall(uint8_t rhport)
{
dcd_edpt_stall(rhport, 0);
}
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif #endif

View File

@ -328,7 +328,7 @@ tusb_error_t usbd_control_xfer_st(uint8_t rhport, tusb_dir_t dir, uint8_t * buff
// Status opposite direction with Zero Length // Status opposite direction with Zero Length
// No need to wait for status to complete therefore // No need to wait for status to complete therefore
// status phase must not call dcd_control_complete/dcd_xfer_complete // status phase must not call dcd_control_complete/dcd_xfer_complete
usbd_control_status(rhport, dir); dcd_control_status(rhport, dir);
OSAL_SUBTASK_END OSAL_SUBTASK_END
} }
@ -354,7 +354,7 @@ static tusb_error_t proc_control_request_st(uint8_t rhport, tusb_control_request
STASK_INVOKE( usbd_control_xfer_st(rhport, p_request->bmRequestType_bit.direction, (uint8_t*) buffer, len ), error ); STASK_INVOKE( usbd_control_xfer_st(rhport, p_request->bmRequestType_bit.direction, (uint8_t*) buffer, len ), error );
}else }else
{ {
usbd_control_stall(rhport); // stall unsupported descriptor dcd_control_stall(rhport); // stall unsupported descriptor
} }
} }
else if (TUSB_REQ_GET_CONFIGURATION == p_request->bRequest ) else if (TUSB_REQ_GET_CONFIGURATION == p_request->bRequest )
@ -368,17 +368,17 @@ static tusb_error_t proc_control_request_st(uint8_t rhport, tusb_control_request
usbd_devices[rhport].state = TUSB_DEVICE_STATE_ADDRESSED; usbd_devices[rhport].state = TUSB_DEVICE_STATE_ADDRESSED;
#ifndef NRF52840_XXAA // nrf52 auto handle set address, we must not return status #ifndef NRF52840_XXAA // nrf52 auto handle set address, we must not return status
usbd_control_status(rhport, p_request->bmRequestType_bit.direction); dcd_control_status(rhport, p_request->bmRequestType_bit.direction);
#endif #endif
} }
else if ( TUSB_REQ_SET_CONFIGURATION == p_request->bRequest ) else if ( TUSB_REQ_SET_CONFIGURATION == p_request->bRequest )
{ {
proc_set_config_req(rhport, (uint8_t) p_request->wValue); proc_set_config_req(rhport, (uint8_t) p_request->wValue);
usbd_control_status(rhport, p_request->bmRequestType_bit.direction); dcd_control_status(rhport, p_request->bmRequestType_bit.direction);
} }
else else
{ {
usbd_control_stall(rhport); // Stall unsupported request dcd_control_stall(rhport); // Stall unsupported request
} }
} }
@ -396,7 +396,7 @@ static tusb_error_t proc_control_request_st(uint8_t rhport, tusb_control_request
STASK_INVOKE( usbd_class_drivers[class_code].control_request_st(rhport, p_request), error ); STASK_INVOKE( usbd_class_drivers[class_code].control_request_st(rhport, p_request), error );
}else }else
{ {
usbd_control_stall(rhport); // Stall unsupported request dcd_control_stall(rhport); // Stall unsupported request
} }
} }
@ -407,17 +407,17 @@ static tusb_error_t proc_control_request_st(uint8_t rhport, tusb_control_request
if (TUSB_REQ_CLEAR_FEATURE == p_request->bRequest ) if (TUSB_REQ_CLEAR_FEATURE == p_request->bRequest )
{ {
dcd_edpt_clear_stall(rhport, u16_low_u8(p_request->wIndex) ); dcd_edpt_clear_stall(rhport, u16_low_u8(p_request->wIndex) );
usbd_control_status(rhport, p_request->bmRequestType_bit.direction); dcd_control_status(rhport, p_request->bmRequestType_bit.direction);
} else } else
{ {
usbd_control_stall(rhport); // Stall unsupported request dcd_control_stall(rhport); // Stall unsupported request
} }
} }
//------------- Unsupported Request -------------// //------------- Unsupported Request -------------//
else else
{ {
usbd_control_stall(rhport); // Stall unsupported request dcd_control_stall(rhport); // Stall unsupported request
} }
OSAL_SUBTASK_END OSAL_SUBTASK_END

View File

@ -52,18 +52,7 @@ void usbd_task( void* param);
// Carry out Data and Status stage of control transfer // Carry out Data and Status stage of control transfer
tusb_error_t usbd_control_xfer_st(uint8_t rhport, tusb_dir_t dir, uint8_t * buffer, uint16_t length); tusb_error_t usbd_control_xfer_st(uint8_t rhport, tusb_dir_t dir, uint8_t * buffer, uint16_t length);
// Return Status of control transfer
// Note dir is value of direction bit in setup packet (aka DATA stage direction)
static inline bool usbd_control_status(uint8_t rhport, tusb_dir_t dir)
{
// status direction is reversed to one in the setup packet
return dcd_control_xfer(rhport, 1-dir, NULL, 0);
}
static inline void usbd_control_stall(uint8_t rhport)
{
dcd_edpt_stall(rhport, 0);
}
#ifdef __cplusplus #ifdef __cplusplus