mirror of
https://github.com/zsa/qmk_firmware.git
synced 2026-05-04 23:12:57 +00:00
Added new USB_Host_ClearPipeStall() convenience function to clear a stall condition on an attached device's endpoint.
Added new USB_Host_GetDeviceDescriptor() convenience function to retrieve the attached device's Device descriptor. Make Pipe_ConfigurePipe() mask the given endpoint number against PIPE_EPNUM_MASK to ensure the endpoint IN direction bit is cleared to prevent endpoint type corruption. Fix documentation mentioning Pipe_GetCurrentToken() function when real name is Pipe_GetPipeToken().
This commit is contained in:
@@ -134,7 +134,7 @@ static uint8_t MassStore_WaitForDataReceived(void)
|
||||
if (Pipe_IsStalled())
|
||||
{
|
||||
/* Clear the stall condition on the OUT pipe */
|
||||
MassStore_ClearPipeStall(MASS_STORE_DATA_OUT_PIPE);
|
||||
USB_Host_ClearPipeStall(MASS_STORE_DATA_OUT_PIPE);
|
||||
|
||||
return PIPE_RWSTREAM_PipeStalled;
|
||||
}
|
||||
@@ -147,7 +147,7 @@ static uint8_t MassStore_WaitForDataReceived(void)
|
||||
if (Pipe_IsStalled())
|
||||
{
|
||||
/* Clear the stall condition on the IN pipe */
|
||||
MassStore_ClearPipeStall(MASS_STORE_DATA_IN_PIPE);
|
||||
USB_Host_ClearPipeStall(MASS_STORE_DATA_IN_PIPE);
|
||||
|
||||
return PIPE_RWSTREAM_PipeStalled;
|
||||
}
|
||||
|
||||
@@ -158,7 +158,6 @@
|
||||
static uint8_t MassStore_GetReturnedStatus(void);
|
||||
#endif
|
||||
|
||||
uint8_t MassStore_ClearPipeStall(const uint8_t EndpointNum);
|
||||
uint8_t MassStore_MassStorageReset(void);
|
||||
uint8_t MassStore_GetMaxLUN(uint8_t* const MaxLUNIndex);
|
||||
uint8_t MassStore_RequestSense(const uint8_t LUNIndex, const SCSI_Request_Sense_Response_t* const SensePtr)
|
||||
|
||||
@@ -144,22 +144,12 @@ void Bluetooth_Management_Task(void)
|
||||
}
|
||||
|
||||
puts_P(PSTR("Bluetooth Dongle Detected.\r\n"));
|
||||
|
||||
/* Standard request to set the device configuration to configuration 1 */
|
||||
USB_ControlRequest = (USB_Request_Header_t)
|
||||
{
|
||||
bmRequestType: (REQDIR_HOSTTODEVICE | REQTYPE_STANDARD | REQREC_DEVICE),
|
||||
bRequest: REQ_SetConfiguration,
|
||||
wValue: 1,
|
||||
wIndex: 0,
|
||||
wLength: 0,
|
||||
};
|
||||
|
||||
/* Select the control pipe for the request transfer */
|
||||
Pipe_SelectPipe(PIPE_CONTROLPIPE);
|
||||
|
||||
/* Send the request, display error and wait for device detatch if request fails */
|
||||
if ((ErrorCode = USB_Host_SendControlRequest(NULL)) != HOST_SENDCONTROL_Successful)
|
||||
/* Set the device configuration to the first configuration (rarely do devices use multiple configurations) */
|
||||
if ((ErrorCode = USB_Host_SetDeviceConfiguration(1)) != HOST_SENDCONTROL_Successful)
|
||||
{
|
||||
puts_P(PSTR("Control Error (Set Configuration).\r\n"));
|
||||
printf_P(PSTR(" -- Error Code: %d\r\n"), ErrorCode);
|
||||
|
||||
@@ -134,7 +134,7 @@ static uint8_t MassStore_WaitForDataReceived(void)
|
||||
if (Pipe_IsStalled())
|
||||
{
|
||||
/* Clear the stall condition on the OUT pipe */
|
||||
MassStore_ClearPipeStall(MASS_STORE_DATA_OUT_PIPE);
|
||||
USB_Host_ClearPipeStall(MASS_STORE_DATA_OUT_PIPE);
|
||||
|
||||
return PIPE_RWSTREAM_PipeStalled;
|
||||
}
|
||||
@@ -147,7 +147,7 @@ static uint8_t MassStore_WaitForDataReceived(void)
|
||||
if (Pipe_IsStalled())
|
||||
{
|
||||
/* Clear the stall condition on the IN pipe */
|
||||
MassStore_ClearPipeStall(MASS_STORE_DATA_IN_PIPE);
|
||||
USB_Host_ClearPipeStall(MASS_STORE_DATA_IN_PIPE);
|
||||
|
||||
return PIPE_RWSTREAM_PipeStalled;
|
||||
}
|
||||
@@ -243,29 +243,6 @@ static uint8_t MassStore_GetReturnedStatus(void)
|
||||
return PIPE_RWSTREAM_NoError;
|
||||
}
|
||||
|
||||
/** Clears the stall condition in the attached device on the nominated endpoint number.
|
||||
*
|
||||
* \param EndpointNum Endpoint number in the attached device whose stall condition is to be cleared
|
||||
*
|
||||
* \return A value from the USB_Host_SendControlErrorCodes_t enum
|
||||
*/
|
||||
uint8_t MassStore_ClearPipeStall(const uint8_t EndpointNum)
|
||||
{
|
||||
USB_ControlRequest = (USB_Request_Header_t)
|
||||
{
|
||||
.bmRequestType = (REQDIR_HOSTTODEVICE | REQTYPE_STANDARD | REQREC_ENDPOINT),
|
||||
.bRequest = REQ_ClearFeature,
|
||||
.wValue = FEATURE_ENDPOINT_HALT,
|
||||
.wIndex = EndpointNum,
|
||||
.wLength = 0,
|
||||
};
|
||||
|
||||
/* Select the control pipe for the request transfer */
|
||||
Pipe_SelectPipe(PIPE_CONTROLPIPE);
|
||||
|
||||
return USB_Host_SendControlRequest(NULL);
|
||||
}
|
||||
|
||||
/** Issues a Mass Storage class specific request to reset the attached device's Mass Storage interface,
|
||||
* readying the device for the next CBW.
|
||||
*
|
||||
|
||||
@@ -158,7 +158,6 @@
|
||||
static uint8_t MassStore_GetReturnedStatus(void);
|
||||
#endif
|
||||
|
||||
uint8_t MassStore_ClearPipeStall(const uint8_t EndpointNum);
|
||||
uint8_t MassStore_MassStorageReset(void);
|
||||
uint8_t MassStore_GetMaxLUN(uint8_t* const MaxLUNIndex);
|
||||
uint8_t MassStore_RequestSense(const uint8_t LUNIndex, const SCSI_Request_Sense_Response_t* const SensePtr)
|
||||
|
||||
Reference in New Issue
Block a user