forked from mfulz_github/qmk_firmware
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:
parent
2b21a1552d
commit
e338cb6f32
|
@ -206,10 +206,6 @@ CFLAGS += -ffunction-sections
|
||||||
CFLAGS += -fpack-struct
|
CFLAGS += -fpack-struct
|
||||||
CFLAGS += -fshort-enums
|
CFLAGS += -fshort-enums
|
||||||
CFLAGS += -fno-inline-small-functions
|
CFLAGS += -fno-inline-small-functions
|
||||||
CFLAGS += -fno-reorder-blocks
|
|
||||||
CFLAGS += -fno-reorder-blocks-and-partition
|
|
||||||
CFLAGS += -fno-reorder-functions
|
|
||||||
CFLAGS += -fno-toplevel-reorder
|
|
||||||
CFLAGS += -Wall
|
CFLAGS += -Wall
|
||||||
CFLAGS += -Wstrict-prototypes
|
CFLAGS += -Wstrict-prototypes
|
||||||
CFLAGS += -Wundef
|
CFLAGS += -Wundef
|
||||||
|
|
|
@ -207,10 +207,6 @@ CFLAGS += -fdata-sections
|
||||||
CFLAGS += -fpack-struct
|
CFLAGS += -fpack-struct
|
||||||
CFLAGS += -fshort-enums
|
CFLAGS += -fshort-enums
|
||||||
CFLAGS += -fno-inline-small-functions
|
CFLAGS += -fno-inline-small-functions
|
||||||
CFLAGS += -fno-reorder-blocks
|
|
||||||
CFLAGS += -fno-reorder-blocks-and-partition
|
|
||||||
CFLAGS += -fno-reorder-functions
|
|
||||||
CFLAGS += -fno-toplevel-reorder
|
|
||||||
CFLAGS += -Wall
|
CFLAGS += -Wall
|
||||||
CFLAGS += -Wstrict-prototypes
|
CFLAGS += -Wstrict-prototypes
|
||||||
CFLAGS += -Wundef
|
CFLAGS += -Wundef
|
||||||
|
|
|
@ -206,10 +206,6 @@ CFLAGS += -ffunction-sections
|
||||||
CFLAGS += -fpack-struct
|
CFLAGS += -fpack-struct
|
||||||
CFLAGS += -fshort-enums
|
CFLAGS += -fshort-enums
|
||||||
CFLAGS += -fno-inline-small-functions
|
CFLAGS += -fno-inline-small-functions
|
||||||
CFLAGS += -fno-reorder-blocks
|
|
||||||
CFLAGS += -fno-reorder-blocks-and-partition
|
|
||||||
CFLAGS += -fno-reorder-functions
|
|
||||||
CFLAGS += -fno-toplevel-reorder
|
|
||||||
CFLAGS += -Wall
|
CFLAGS += -Wall
|
||||||
CFLAGS += -Wstrict-prototypes
|
CFLAGS += -Wstrict-prototypes
|
||||||
CFLAGS += -Wundef
|
CFLAGS += -Wundef
|
||||||
|
|
|
@ -134,7 +134,7 @@ static uint8_t MassStore_WaitForDataReceived(void)
|
||||||
if (Pipe_IsStalled())
|
if (Pipe_IsStalled())
|
||||||
{
|
{
|
||||||
/* Clear the stall condition on the OUT pipe */
|
/* 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;
|
return PIPE_RWSTREAM_PipeStalled;
|
||||||
}
|
}
|
||||||
|
@ -147,7 +147,7 @@ static uint8_t MassStore_WaitForDataReceived(void)
|
||||||
if (Pipe_IsStalled())
|
if (Pipe_IsStalled())
|
||||||
{
|
{
|
||||||
/* Clear the stall condition on the IN pipe */
|
/* 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;
|
return PIPE_RWSTREAM_PipeStalled;
|
||||||
}
|
}
|
||||||
|
|
|
@ -158,7 +158,6 @@
|
||||||
static uint8_t MassStore_GetReturnedStatus(void);
|
static uint8_t MassStore_GetReturnedStatus(void);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
uint8_t MassStore_ClearPipeStall(const uint8_t EndpointNum);
|
|
||||||
uint8_t MassStore_MassStorageReset(void);
|
uint8_t MassStore_MassStorageReset(void);
|
||||||
uint8_t MassStore_GetMaxLUN(uint8_t* const MaxLUNIndex);
|
uint8_t MassStore_GetMaxLUN(uint8_t* const MaxLUNIndex);
|
||||||
uint8_t MassStore_RequestSense(const uint8_t LUNIndex, const SCSI_Request_Sense_Response_t* const SensePtr)
|
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"));
|
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 */
|
/* Select the control pipe for the request transfer */
|
||||||
Pipe_SelectPipe(PIPE_CONTROLPIPE);
|
Pipe_SelectPipe(PIPE_CONTROLPIPE);
|
||||||
|
|
||||||
/* Send the request, display error and wait for device detatch if request fails */
|
/* Set the device configuration to the first configuration (rarely do devices use multiple configurations) */
|
||||||
if ((ErrorCode = USB_Host_SendControlRequest(NULL)) != HOST_SENDCONTROL_Successful)
|
if ((ErrorCode = USB_Host_SetDeviceConfiguration(1)) != HOST_SENDCONTROL_Successful)
|
||||||
{
|
{
|
||||||
puts_P(PSTR("Control Error (Set Configuration).\r\n"));
|
puts_P(PSTR("Control Error (Set Configuration).\r\n"));
|
||||||
printf_P(PSTR(" -- Error Code: %d\r\n"), ErrorCode);
|
printf_P(PSTR(" -- Error Code: %d\r\n"), ErrorCode);
|
||||||
|
|
|
@ -134,7 +134,7 @@ static uint8_t MassStore_WaitForDataReceived(void)
|
||||||
if (Pipe_IsStalled())
|
if (Pipe_IsStalled())
|
||||||
{
|
{
|
||||||
/* Clear the stall condition on the OUT pipe */
|
/* 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;
|
return PIPE_RWSTREAM_PipeStalled;
|
||||||
}
|
}
|
||||||
|
@ -147,7 +147,7 @@ static uint8_t MassStore_WaitForDataReceived(void)
|
||||||
if (Pipe_IsStalled())
|
if (Pipe_IsStalled())
|
||||||
{
|
{
|
||||||
/* Clear the stall condition on the IN pipe */
|
/* 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;
|
return PIPE_RWSTREAM_PipeStalled;
|
||||||
}
|
}
|
||||||
|
@ -243,29 +243,6 @@ static uint8_t MassStore_GetReturnedStatus(void)
|
||||||
return PIPE_RWSTREAM_NoError;
|
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,
|
/** Issues a Mass Storage class specific request to reset the attached device's Mass Storage interface,
|
||||||
* readying the device for the next CBW.
|
* readying the device for the next CBW.
|
||||||
*
|
*
|
||||||
|
|
|
@ -158,7 +158,6 @@
|
||||||
static uint8_t MassStore_GetReturnedStatus(void);
|
static uint8_t MassStore_GetReturnedStatus(void);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
uint8_t MassStore_ClearPipeStall(const uint8_t EndpointNum);
|
|
||||||
uint8_t MassStore_MassStorageReset(void);
|
uint8_t MassStore_MassStorageReset(void);
|
||||||
uint8_t MassStore_GetMaxLUN(uint8_t* const MaxLUNIndex);
|
uint8_t MassStore_GetMaxLUN(uint8_t* const MaxLUNIndex);
|
||||||
uint8_t MassStore_RequestSense(const uint8_t LUNIndex, const SCSI_Request_Sense_Response_t* const SensePtr)
|
uint8_t MassStore_RequestSense(const uint8_t LUNIndex, const SCSI_Request_Sense_Response_t* const SensePtr)
|
||||||
|
|
|
@ -116,6 +116,8 @@
|
||||||
*
|
*
|
||||||
* \note This global is only present if the user application can be a USB host.
|
* \note This global is only present if the user application can be a USB host.
|
||||||
*
|
*
|
||||||
|
* \see \ref USB_Host_States_t for a list of possible host states
|
||||||
|
*
|
||||||
* \ingroup Group_Host
|
* \ingroup Group_Host
|
||||||
*/
|
*/
|
||||||
extern volatile uint8_t USB_HostState;
|
extern volatile uint8_t USB_HostState;
|
||||||
|
|
|
@ -302,4 +302,39 @@ uint8_t USB_Host_SetDeviceConfiguration(uint8_t ConfigNumber)
|
||||||
return USB_Host_SendControlRequest(NULL);
|
return USB_Host_SendControlRequest(NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint8_t USB_Host_GetDeviceDescriptor(USB_Descriptor_Device_t* DeviceDescriptorPtr)
|
||||||
|
{
|
||||||
|
USB_ControlRequest = (USB_Request_Header_t)
|
||||||
|
{
|
||||||
|
bmRequestType: (REQDIR_DEVICETOHOST | REQTYPE_STANDARD | REQREC_DEVICE),
|
||||||
|
bRequest: REQ_GetDescriptor,
|
||||||
|
wValue: (DTYPE_Device << 8),
|
||||||
|
wIndex: 0,
|
||||||
|
wLength: sizeof(USB_Descriptor_Device_t),
|
||||||
|
};
|
||||||
|
|
||||||
|
Pipe_SelectPipe(PIPE_CONTROLPIPE);
|
||||||
|
|
||||||
|
return USB_Host_SendControlRequest(DeviceDescriptorPtr);
|
||||||
|
}
|
||||||
|
|
||||||
|
uint8_t USB_Host_ClearPipeStall(uint8_t EndpointNum)
|
||||||
|
{
|
||||||
|
if (Pipe_GetPipeToken() == PIPE_TOKEN_IN)
|
||||||
|
EndpointNum |= (1 << 7);
|
||||||
|
|
||||||
|
USB_ControlRequest = (USB_Request_Header_t)
|
||||||
|
{
|
||||||
|
.bmRequestType = (REQDIR_HOSTTODEVICE | REQTYPE_STANDARD | REQREC_ENDPOINT),
|
||||||
|
.bRequest = REQ_ClearFeature,
|
||||||
|
.wValue = FEATURE_ENDPOINT_HALT,
|
||||||
|
.wIndex = EndpointNum,
|
||||||
|
.wLength = 0,
|
||||||
|
};
|
||||||
|
|
||||||
|
Pipe_SelectPipe(PIPE_CONTROLPIPE);
|
||||||
|
|
||||||
|
return USB_Host_SendControlRequest(NULL);
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -47,6 +47,8 @@
|
||||||
|
|
||||||
#include "../../../Common/Common.h"
|
#include "../../../Common/Common.h"
|
||||||
#include "../HighLevel/USBInterrupt.h"
|
#include "../HighLevel/USBInterrupt.h"
|
||||||
|
#include "../HighLevel/StdDescriptors.h"
|
||||||
|
#include "Pipe.h"
|
||||||
|
|
||||||
/* Enable C linkage for C++ Compilers: */
|
/* Enable C linkage for C++ Compilers: */
|
||||||
#if defined(__cplusplus)
|
#if defined(__cplusplus)
|
||||||
|
@ -185,6 +187,29 @@
|
||||||
* \return A value from the \ref USB_Host_SendControlErrorCodes_t enum to indicate the result.
|
* \return A value from the \ref USB_Host_SendControlErrorCodes_t enum to indicate the result.
|
||||||
*/
|
*/
|
||||||
uint8_t USB_Host_SetDeviceConfiguration(uint8_t ConfigNumber);
|
uint8_t USB_Host_SetDeviceConfiguration(uint8_t ConfigNumber);
|
||||||
|
|
||||||
|
/** Convenience function. This routine sends a GetDescriptor standard request to the attached
|
||||||
|
* device, requesting the device descriptor. This can be used to easily retrieve information
|
||||||
|
* about the device such as its VID, PID and power requirements.
|
||||||
|
*
|
||||||
|
* \note After this routine returns, the control pipe will be selected.
|
||||||
|
*
|
||||||
|
* \param DeviceDescriptorPtr Pointer to the destination device descriptor structure where
|
||||||
|
* the read data is to be stored
|
||||||
|
*
|
||||||
|
* \return A value from the \ref USB_Host_SendControlErrorCodes_t enum to indicate the result.
|
||||||
|
*/
|
||||||
|
uint8_t USB_Host_GetDeviceDescriptor(USB_Descriptor_Device_t* DeviceDescriptorPtr);
|
||||||
|
|
||||||
|
/** Clears a stall condition on the given pipe, via a ClearFeature request to the attached device.
|
||||||
|
*
|
||||||
|
* \note After this routine returns, the control pipe will be selected.
|
||||||
|
*
|
||||||
|
* \param EndpointIndex Index of the endpoint to clear
|
||||||
|
*
|
||||||
|
* \return A value from the \ref USB_Host_SendControlErrorCodes_t enum to indicate the result.
|
||||||
|
*/
|
||||||
|
uint8_t USB_Host_ClearPipeStall(uint8_t EndpointIndex);
|
||||||
|
|
||||||
/* Enums: */
|
/* Enums: */
|
||||||
/** Enum for the various states of the USB Host state machine. Only some states are
|
/** Enum for the various states of the USB Host state machine. Only some states are
|
||||||
|
|
|
@ -45,7 +45,7 @@ bool Pipe_ConfigurePipe(const uint8_t Number, const uint8_t Type, const uint8_t
|
||||||
|
|
||||||
UPCFG1X = 0;
|
UPCFG1X = 0;
|
||||||
|
|
||||||
UPCFG0X = ((Type << EPTYPE0) | Token | (EndpointNumber << PEPNUM0));
|
UPCFG0X = ((Type << EPTYPE0) | Token | ((EndpointNumber & PIPE_EPNUM_MASK) << PEPNUM0));
|
||||||
UPCFG1X = ((1 << ALLOC) | Banks | Pipe_BytesToEPSizeMask(Size));
|
UPCFG1X = ((1 << ALLOC) | Banks | Pipe_BytesToEPSizeMask(Size));
|
||||||
|
|
||||||
return Pipe_IsConfigured();
|
return Pipe_IsConfigured();
|
||||||
|
|
|
@ -219,7 +219,7 @@
|
||||||
*
|
*
|
||||||
* \return The current pipe token, as a PIPE_TOKEN_* mask
|
* \return The current pipe token, as a PIPE_TOKEN_* mask
|
||||||
*/
|
*/
|
||||||
static inline uint8_t Pipe_GetCurrentToken(void);
|
static inline uint8_t Pipe_GetPipeToken(void);
|
||||||
|
|
||||||
/** Sets the token for the currently selected pipe to one of the tokens specified by the PIPE_TOKEN_*
|
/** Sets the token for the currently selected pipe to one of the tokens specified by the PIPE_TOKEN_*
|
||||||
* masks. This can be used on CONTROL type pipes, to allow for bidirectional transfer of data during
|
* masks. This can be used on CONTROL type pipes, to allow for bidirectional transfer of data during
|
||||||
|
|
|
@ -20,8 +20,13 @@
|
||||||
* internal control
|
* internal control
|
||||||
* - Added new USB_Host_SetDeviceConfiguration() convenience function for easy configuration selection of devices while in USB
|
* - Added new USB_Host_SetDeviceConfiguration() convenience function for easy configuration selection of devices while in USB
|
||||||
* host mode
|
* host mode
|
||||||
|
* - 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
|
||||||
* - Added USB Missle Launcher project, submitted by Dave Fletcher
|
* - Added USB Missle Launcher project, submitted by Dave Fletcher
|
||||||
* - Pipe_GetErrorFlags() now returns additional error flags for overflow and underflow errors
|
* - Pipe_GetErrorFlags() now returns additional error flags for overflow and underflow errors
|
||||||
|
* - 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()
|
||||||
*
|
*
|
||||||
*
|
*
|
||||||
* \section Sec_ChangeLog090605 Version 090605
|
* \section Sec_ChangeLog090605 Version 090605
|
||||||
|
|
|
@ -21,4 +21,7 @@
|
||||||
* - Port LUFA to the Atmel ARM7 series microcontrollers
|
* - Port LUFA to the Atmel ARM7 series microcontrollers
|
||||||
* - Remake AVRStudio project files
|
* - Remake AVRStudio project files
|
||||||
* - Master LUFA include file
|
* - Master LUFA include file
|
||||||
|
* - Debug mode for pipe/endpoint calls
|
||||||
|
* - Device descriptor get routines
|
||||||
|
* - Add ClearPipeStall host function
|
||||||
*/
|
*/
|
||||||
|
|
Loading…
Reference in New Issue