33 uint32_t g_u32HsEpStallLock = 0ul;
35 static uint8_t *g_hsusbd_CtrlInPointer = 0;
36 static uint32_t g_hsusbd_CtrlMaxPktSize = 64ul;
37 static uint8_t g_hsusbd_UsbConfig = 0ul;
38 static uint8_t g_hsusbd_UsbAltInterface = 0ul;
39 static uint8_t g_hsusbd_EnableTestMode = 0ul;
40 static uint8_t g_hsusbd_TestSelector = 0ul;
43 #pragma data_alignment=4 44 static uint8_t g_hsusbd_buf[12];
49 uint8_t
volatile g_hsusbd_Configured = 0ul;
50 uint8_t g_hsusbd_CtrlZero = 0ul;
51 uint8_t g_hsusbd_UsbAddr = 0ul;
52 uint8_t g_hsusbd_ShortPacket = 0ul;
53 uint32_t
volatile g_hsusbd_DmaDone = 0ul;
54 uint32_t g_hsusbd_CtrlInSize = 0ul;
70 g_hsusbd_sInfo = param;
71 g_hsusbd_pfnClassRequest = pfnClassReq;
72 g_hsusbd_pfnSetInterface = pfnSetInterface;
75 g_hsusbd_CtrlMaxPktSize = g_hsusbd_sInfo->
gu8DevDesc[7];
86 HSUSBD->EP[EPA].EPMPS = 0x20ul;
87 if (
HSUSBD->EP[EPA].EPMPS == 0x20ul)
89 HSUSBD->EP[EPA].EPMPS = 0x0ul;
139 if (g_hsusbd_pfnClassRequest !=
NULL)
141 g_hsusbd_pfnClassRequest();
147 if (g_hsusbd_pfnVendorRequest !=
NULL)
149 g_hsusbd_pfnVendorRequest();
177 g_hsusbd_CtrlZero = (uint8_t)0ul;
179 switch ((gUsbCmd.
wValue & 0xff00ul) >> 8)
184 u32Len = Minimum(u32Len, LEN_DEVICE);
191 uint32_t u32TotalLen;
192 if ((
HSUSBD->OPER & 0x04ul) == 0x04ul)
195 u32TotalLen = g_hsusbd_sInfo->
gu8ConfigDesc[2] + (u32TotalLen << 8);
197 if (u32Len > u32TotalLen)
199 u32Len = u32TotalLen;
200 if ((u32Len % g_hsusbd_CtrlMaxPktSize) == 0ul)
202 g_hsusbd_CtrlZero = (uint8_t)1ul;
212 if (u32Len > u32TotalLen)
214 u32Len = u32TotalLen;
215 if ((u32Len % g_hsusbd_CtrlMaxPktSize) == 0ul)
217 g_hsusbd_CtrlZero = (uint8_t)1ul;
228 u32Len = Minimum(u32Len, LEN_QUALIFIER);
233 case DESC_OTHERSPEED:
235 uint32_t u32TotalLen;
236 if ((
HSUSBD->OPER & 0x04ul) == 0x04ul)
241 if (u32Len > u32TotalLen)
243 u32Len = u32TotalLen;
244 if ((u32Len % g_hsusbd_CtrlMaxPktSize) == 0ul)
246 g_hsusbd_CtrlZero = (uint8_t)1ul;
256 if (u32Len > u32TotalLen)
258 u32Len = u32TotalLen;
259 if ((u32Len % g_hsusbd_CtrlMaxPktSize) == 0ul)
261 g_hsusbd_CtrlZero = (uint8_t)1ul;
272 uint32_t u32ConfigDescOffset;
273 u32Len = Minimum(u32Len, LEN_HID);
284 if ((u32Len % g_hsusbd_CtrlMaxPktSize) == 0ul)
286 g_hsusbd_CtrlZero = (uint8_t)1ul;
295 if((gUsbCmd.
wValue & 0xfful) < 8ul)
300 if ((u32Len % g_hsusbd_CtrlMaxPktSize) == 0ul)
302 g_hsusbd_CtrlZero = (uint8_t)1ul;
336 g_hsusbd_CtrlInPointer = 0;
337 g_hsusbd_CtrlInSize = 0ul;
344 case GET_CONFIGURATION:
378 g_hsusbd_buf[0] = (uint8_t)1ul;
382 g_hsusbd_buf[0] = (uint8_t)0ul;
388 g_hsusbd_buf[0] = (uint8_t)0ul;
393 uint8_t ep = (uint8_t)(gUsbCmd.
wIndex & 0xFul);
394 g_hsusbd_buf[0] = (uint8_t)
HSUSBD_GetStall((uint32_t)ep)? (uint8_t)1 : (uint8_t)0;
396 g_hsusbd_buf[1] = (uint8_t)0ul;
417 if((gUsbCmd.
wValue & 0xfful) == FEATURE_ENDPOINT_HALT)
424 epNum = (uint32_t)(gUsbCmd.
wIndex & 0xFul);
425 for (i=0ul; i<HSUSBD_MAX_EP; i++)
427 if ((((
HSUSBD->EP[i].EPCFG & 0xf0ul) >> 4) == epNum) && ((g_u32HsEpStallLock & (1ul << i)) == 0ul))
441 g_hsusbd_UsbAddr = (uint8_t)gUsbCmd.
wValue;
448 case SET_CONFIGURATION:
450 g_hsusbd_UsbConfig = (uint8_t)gUsbCmd.
wValue;
451 g_hsusbd_Configured = (uint8_t)1ul;
460 if ((gUsbCmd.
wValue & 0x3ul) == 2ul)
462 g_hsusbd_EnableTestMode = (uint8_t)1ul;
463 g_hsusbd_TestSelector = (uint8_t)(gUsbCmd.
wIndex >> 8);
465 if ((gUsbCmd.
wValue & 0x3ul) == 3ul)
478 g_hsusbd_UsbAltInterface = (uint8_t)gUsbCmd.
wValue;
479 if (g_hsusbd_pfnSetInterface !=
NULL)
481 g_hsusbd_pfnSetInterface((uint32_t)g_hsusbd_UsbAltInterface);
509 #define TEST_J 0x01ul 510 #define TEST_K 0x02ul 511 #define TEST_SE0_NAK 0x03ul 512 #define TEST_PACKET 0x04ul 513 #define TEST_FORCE_ENABLE 0x05ul 525 case SET_CONFIGURATION:
527 if (g_hsusbd_UsbConfig == 0ul)
531 for (i=0ul; i<HSUSBD_MAX_EP; i++)
533 if ((
HSUSBD->EP[i].EPCFG & 0x1ul) == 0x1ul)
543 if(gUsbCmd.
wValue == FEATURE_ENDPOINT_HALT)
546 idx = (uint32_t)(gUsbCmd.
wIndex & 0xFul);
549 else if (g_hsusbd_EnableTestMode)
551 g_hsusbd_EnableTestMode = (uint8_t)0ul;
552 if (g_hsusbd_TestSelector == TEST_J)
556 else if (g_hsusbd_TestSelector == TEST_K)
560 else if (g_hsusbd_TestSelector == TEST_SE0_NAK)
562 HSUSBD->TEST = TEST_SE0_NAK;
564 else if (g_hsusbd_TestSelector == TEST_PACKET)
566 HSUSBD->TEST = TEST_PACKET;
568 else if (g_hsusbd_TestSelector == TEST_FORCE_ENABLE)
570 HSUSBD->TEST = TEST_FORCE_ENABLE;
577 if(gUsbCmd.
wValue == FEATURE_ENDPOINT_HALT)
580 idx = (uint32_t)(gUsbCmd.
wIndex & 0xFul);
603 g_hsusbd_CtrlInPointer = pu8Buf;
604 g_hsusbd_CtrlInSize = u32Size;
620 uint32_t
volatile i, cnt;
622 if(g_hsusbd_CtrlInSize >= g_hsusbd_CtrlMaxPktSize)
625 cnt = g_hsusbd_CtrlMaxPktSize >> 2;
626 for (i=0ul; i<cnt; i++)
628 HSUSBD->CEPDAT = *(uint32_t *)g_hsusbd_CtrlInPointer;
629 g_hsusbd_CtrlInPointer = (uint8_t *)(g_hsusbd_CtrlInPointer + 4ul);
632 g_hsusbd_CtrlInSize -= g_hsusbd_CtrlMaxPktSize;
637 cnt = g_hsusbd_CtrlInSize >> 2;
638 for (i=0ul; i<cnt; i++)
640 HSUSBD->CEPDAT = *(uint32_t *)g_hsusbd_CtrlInPointer;
641 g_hsusbd_CtrlInPointer += 4ul;
644 for (i=0ul; i<(g_hsusbd_CtrlInSize % 4ul); i++)
646 u8Value = *(uint8_t *)(g_hsusbd_CtrlInPointer+i);
651 g_hsusbd_CtrlInPointer = 0;
652 g_hsusbd_CtrlInSize = 0ul;
673 for (i=0ul; i<u32Size; i++)
695 g_hsusbd_UsbAddr = (uint8_t)0ul;
696 g_hsusbd_DmaDone = 0ul;
697 g_hsusbd_ShortPacket = (uint8_t)0ul;
698 g_hsusbd_Configured = (uint8_t)0ul;
715 g_hsusbd_pfnVendorRequest = pfnVendorReq;
#define HSUSBD_CEPCTL_STALLEN_Msk
#define HSUSBD_CEPCTL_NAKCLR
void HSUSBD_StandardRequest(void)
Process USB standard request.
uint32_t * gu32ConfigHidDescIdx
#define HSUSBD_CEPINTEN_INTKIEN_Msk
void HSUSBD_CtrlIn(void)
Start Control IN transfer.
#define HSUSBD_SET_CEP_STATE(flag)
#define HSUSBD_ENABLE_CEP_INT(intr)
#define HSUSBD_START_CEP_IN(size)
#define HSOTG_CTL_HNPREQEN_Msk
void HSUSBD_SetVendorRequest(HSUSBD_VENDOR_REQ pfnVendorReq)
HSUSBD Set Vendor Request.
void HSUSBD_ProcessSetupPacket(void)
Process Setup Packet.
#define outpb(port, value)
Set a 8-bit unsigned value to specified I/O port.
#define HSUSBD_ENABLE_PHY()
#define HSOTG_CTL_BUSREQ_Msk
void HSUSBD_UpdateDeviceState(void)
Update Device State.
NuMicro peripheral access layer header file.
#define HSUSBD_CEPINTSTS_RXPKIF_Msk
int HSUSBD_GetDescriptor(void)
Get Descriptor request.
void *__dso_handle __attribute__((weak))
void HSUSBD_SwReset(void)
Clear all software flags.
__STATIC_INLINE void HSUSBD_ClearStall(uint32_t u32EpNum)
Clear USB endpoint stall state.
uint8_t ** gu8HidReportDesc
uint8_t * gu8HSOtherConfigDesc
#define HSUSBD_CEPINTEN_STSDONEIEN_Msk
void(* HSUSBD_SET_INTERFACE_REQ)(uint32_t u32AltInterface)
__STATIC_INLINE void HSUSBD_SetStall(uint32_t u32EpNum)
Set USB endpoint stall state.
#define HSUSBD_CEPINTSTS_STSDONEIF_Msk
#define inpb(port)
Get a 8-bit unsigned value from specified I/O port.
void HSUSBD_Open(S_HSUSBD_INFO_T *param, HSUSBD_CLASS_REQ pfnClassReq, HSUSBD_SET_INTERFACE_REQ pfnSetInterface)
HSUSBD Initial.
#define HSUSBD_EP_RSPCTL_TOGGLE
void HSUSBD_PrepareCtrlIn(uint8_t pu8Buf[], uint32_t u32Size)
Prepare Control IN transaction.
void HSUSBD_CtrlOut(uint8_t pu8Buf[], uint32_t u32Size)
Start Control OUT transaction.
#define HSUSBD_CEPINTSTS_INTKIF_Msk
#define HSUSBD_CLR_CEP_INT_FLAG(flag)
#define HSUSBD_BUSINTEN_PHYCLKVLDIEN_Msk
void(* HSUSBD_VENDOR_REQ)(void)
void HSUSBD_Start(void)
HSUSBD Start.
__STATIC_INLINE uint32_t HSUSBD_GetStall(uint32_t u32EpNum)
Get USB endpoint stall state.
#define HSUSBD_SET_ADDR(addr)
uint32_t * gu32HidReportSize
void(* HSUSBD_CLASS_REQ)(void)
uint8_t * gu8FullConfigDesc
#define NULL
NULL pointer.
uint8_t * gu8FSOtherConfigDesc