68 #ifdef HAL_PCD_MODULE_ENABLED 70 #if defined (USB) || defined (USB_OTG_FS) 79 #define PCD_MIN(a, b) (((a) < (b)) ? (a) : (b)) 80 #define PCD_MAX(a, b) (((a) > (b)) ? (a) : (b)) 89 #if defined (USB_OTG_FS) 128 #if defined (USB_OTG_FS) 129 USB_OTG_GlobalTypeDef *USBx;
142 #if defined (USB_OTG_FS) 143 USBx = hpcd->Instance;
151 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 166 if (hpcd->MspInitCallback == NULL)
172 hpcd->MspInitCallback(hpcd);
181 #if defined (USB_OTG_FS) 183 if ((USBx->CID & (0x1U << 8)) == 0U)
185 hpcd->Init.dma_enable = 0U;
190 __HAL_PCD_DISABLE(hpcd);
203 for (i = 0U; i < hpcd->Init.dev_endpoints; i++)
206 hpcd->IN_ep[i].is_in = 1U;
207 hpcd->IN_ep[i].num = i;
208 hpcd->IN_ep[i].tx_fifo_num = i;
210 hpcd->IN_ep[i].type = EP_TYPE_CTRL;
211 hpcd->IN_ep[i].maxpacket = 0U;
212 hpcd->IN_ep[i].xfer_buff = 0U;
213 hpcd->IN_ep[i].xfer_len = 0U;
216 for (i = 0U; i < hpcd->Init.dev_endpoints; i++)
218 hpcd->OUT_ep[i].is_in = 0U;
219 hpcd->OUT_ep[i].num = i;
221 hpcd->OUT_ep[i].type = EP_TYPE_CTRL;
222 hpcd->OUT_ep[i].maxpacket = 0U;
223 hpcd->OUT_ep[i].xfer_buff = 0U;
224 hpcd->OUT_ep[i].xfer_len = 0U;
234 hpcd->USB_Address = 0U;
238 if (hpcd->Init.lpm_enable == 1U)
266 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 267 if (hpcd->MspDeInitCallback == NULL)
273 hpcd->MspDeInitCallback(hpcd);
314 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 335 HAL_StatusTypeDef status =
HAL_OK;
337 if (pCallback == NULL)
340 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
351 hpcd->SOFCallback = pCallback;
355 hpcd->SetupStageCallback = pCallback;
359 hpcd->ResetCallback = pCallback;
363 hpcd->SuspendCallback = pCallback;
367 hpcd->ResumeCallback = pCallback;
371 hpcd->ConnectCallback = pCallback;
375 hpcd->DisconnectCallback = pCallback;
379 hpcd->MspInitCallback = pCallback;
383 hpcd->MspDeInitCallback = pCallback;
388 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
399 hpcd->MspInitCallback = pCallback;
403 hpcd->MspDeInitCallback = pCallback;
408 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
417 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
446 HAL_StatusTypeDef status =
HAL_OK;
494 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
515 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
525 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
545 HAL_StatusTypeDef status =
HAL_OK;
547 if (pCallback == NULL)
550 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
560 hpcd->DataOutStageCallback = pCallback;
565 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
585 HAL_StatusTypeDef status =
HAL_OK;
597 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
618 HAL_StatusTypeDef status =
HAL_OK;
620 if (pCallback == NULL)
623 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
633 hpcd->DataInStageCallback = pCallback;
638 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
658 HAL_StatusTypeDef status =
HAL_OK;
670 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
691 HAL_StatusTypeDef status =
HAL_OK;
693 if (pCallback == NULL)
696 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
706 hpcd->ISOOUTIncompleteCallback = pCallback;
711 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
731 HAL_StatusTypeDef status =
HAL_OK;
743 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
764 HAL_StatusTypeDef status =
HAL_OK;
766 if (pCallback == NULL)
769 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
779 hpcd->ISOINIncompleteCallback = pCallback;
784 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
804 HAL_StatusTypeDef status =
HAL_OK;
816 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
837 HAL_StatusTypeDef status =
HAL_OK;
839 if (pCallback == NULL)
842 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
852 hpcd->BCDCallback = pCallback;
857 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
877 HAL_StatusTypeDef status =
HAL_OK;
889 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
910 HAL_StatusTypeDef status =
HAL_OK;
912 if (pCallback == NULL)
915 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
925 hpcd->LPMCallback = pCallback;
930 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
950 HAL_StatusTypeDef status =
HAL_OK;
962 hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK;
1001 #if defined (USB_OTG_FS) 1002 USB_OTG_GlobalTypeDef *USBx = hpcd->Instance;
1006 #if defined (USB_OTG_FS) 1007 if (hpcd->Init.battery_charging_enable == 1U)
1010 USBx->GCCFG |= USB_OTG_GCCFG_PWRDWN;
1014 __HAL_PCD_ENABLE(hpcd);
1027 __HAL_PCD_DISABLE(hpcd);
1040 #if defined (USB_OTG_FS) 1048 USB_OTG_GlobalTypeDef *USBx = hpcd->Instance;
1049 uint32_t USBx_BASE = (uint32_t)USBx;
1050 uint32_t i, ep_intr, epint, epnum = 0U;
1051 uint32_t fifoemptymsk, temp;
1055 if (
USB_GetMode(hpcd->Instance) == USB_OTG_MODE_DEVICE)
1058 if (__HAL_PCD_IS_INVALID_INTERRUPT(hpcd))
1063 if (__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_MMIS))
1066 __HAL_PCD_CLEAR_FLAG(hpcd, USB_OTG_GINTSTS_MMIS);
1069 if (__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_OEPINT))
1076 while (ep_intr != 0U)
1078 if ((ep_intr & 0x1U) != 0U)
1082 if ((epint & USB_OTG_DOEPINT_XFRC) == USB_OTG_DOEPINT_XFRC)
1084 CLEAR_OUT_EP_INTR(epnum, USB_OTG_DOEPINT_XFRC);
1088 if ((epint & USB_OTG_DOEPINT_STUP) == USB_OTG_DOEPINT_STUP)
1092 CLEAR_OUT_EP_INTR(epnum, USB_OTG_DOEPINT_STUP);
1095 if ((epint & USB_OTG_DOEPINT_OTEPDIS) == USB_OTG_DOEPINT_OTEPDIS)
1097 CLEAR_OUT_EP_INTR(epnum, USB_OTG_DOEPINT_OTEPDIS);
1101 if ((epint & USB_OTG_DOEPINT_OTEPSPR) == USB_OTG_DOEPINT_OTEPSPR)
1103 CLEAR_OUT_EP_INTR(epnum, USB_OTG_DOEPINT_OTEPSPR);
1107 if ((epint & USB_OTG_DOEPINT_NAK) == USB_OTG_DOEPINT_NAK)
1109 CLEAR_OUT_EP_INTR(epnum, USB_OTG_DOEPINT_NAK);
1117 if (__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_IEPINT))
1124 while (ep_intr != 0U)
1126 if ((ep_intr & 0x1U) != 0U)
1130 if ((epint & USB_OTG_DIEPINT_XFRC) == USB_OTG_DIEPINT_XFRC)
1132 fifoemptymsk = (uint32_t)(0x1UL << (epnum & EP_ADDR_MSK));
1133 USBx_DEVICE->DIEPEMPMSK &= ~fifoemptymsk;
1135 CLEAR_IN_EP_INTR(epnum, USB_OTG_DIEPINT_XFRC);
1137 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 1138 hpcd->DataInStageCallback(hpcd, (uint8_t)epnum);
1143 if ((epint & USB_OTG_DIEPINT_TOC) == USB_OTG_DIEPINT_TOC)
1145 CLEAR_IN_EP_INTR(epnum, USB_OTG_DIEPINT_TOC);
1147 if ((epint & USB_OTG_DIEPINT_ITTXFE) == USB_OTG_DIEPINT_ITTXFE)
1149 CLEAR_IN_EP_INTR(epnum, USB_OTG_DIEPINT_ITTXFE);
1151 if ((epint & USB_OTG_DIEPINT_INEPNE) == USB_OTG_DIEPINT_INEPNE)
1153 CLEAR_IN_EP_INTR(epnum, USB_OTG_DIEPINT_INEPNE);
1155 if ((epint & USB_OTG_DIEPINT_EPDISD) == USB_OTG_DIEPINT_EPDISD)
1157 CLEAR_IN_EP_INTR(epnum, USB_OTG_DIEPINT_EPDISD);
1159 if ((epint & USB_OTG_DIEPINT_TXFE) == USB_OTG_DIEPINT_TXFE)
1170 if (__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_WKUINT))
1173 USBx_DEVICE->DCTL &= ~USB_OTG_DCTL_RWUSIG;
1175 if (hpcd->LPM_State ==
LPM_L1)
1177 hpcd->LPM_State =
LPM_L0;
1179 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 1187 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 1188 hpcd->ResumeCallback(hpcd);
1194 __HAL_PCD_CLEAR_FLAG(hpcd, USB_OTG_GINTSTS_WKUINT);
1198 if (__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_USBSUSP))
1200 if ((USBx_DEVICE->DSTS & USB_OTG_DSTS_SUSPSTS) == USB_OTG_DSTS_SUSPSTS)
1202 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 1203 hpcd->SuspendCallback(hpcd);
1208 __HAL_PCD_CLEAR_FLAG(hpcd, USB_OTG_GINTSTS_USBSUSP);
1212 if (__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_LPMINT))
1214 __HAL_PCD_CLEAR_FLAG(hpcd, USB_OTG_GINTSTS_LPMINT);
1216 if (hpcd->LPM_State ==
LPM_L0)
1218 hpcd->LPM_State =
LPM_L1;
1219 hpcd->BESL = (hpcd->Instance->GLPMCFG & USB_OTG_GLPMCFG_BESL) >> 2U;
1221 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 1229 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 1230 hpcd->SuspendCallback(hpcd);
1238 if (__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_USBRST))
1240 USBx_DEVICE->DCTL &= ~USB_OTG_DCTL_RWUSIG;
1243 for (i = 0U; i < hpcd->Init.dev_endpoints; i++)
1245 USBx_INEP(i)->DIEPINT = 0xFB7FU;
1246 USBx_INEP(i)->DIEPCTL &= ~USB_OTG_DIEPCTL_STALL;
1247 USBx_OUTEP(i)->DOEPINT = 0xFB7FU;
1248 USBx_OUTEP(i)->DOEPCTL &= ~USB_OTG_DOEPCTL_STALL;
1250 USBx_DEVICE->DAINTMSK |= 0x10001U;
1252 if (hpcd->Init.use_dedicated_ep1 != 0U)
1254 USBx_DEVICE->DOUTEP1MSK |= USB_OTG_DOEPMSK_STUPM |
1255 USB_OTG_DOEPMSK_XFRCM |
1256 USB_OTG_DOEPMSK_EPDM;
1258 USBx_DEVICE->DINEP1MSK |= USB_OTG_DIEPMSK_TOM |
1259 USB_OTG_DIEPMSK_XFRCM |
1260 USB_OTG_DIEPMSK_EPDM;
1264 USBx_DEVICE->DOEPMSK |= USB_OTG_DOEPMSK_STUPM |
1265 USB_OTG_DOEPMSK_XFRCM |
1266 USB_OTG_DOEPMSK_EPDM |
1267 USB_OTG_DOEPMSK_OTEPSPRM |
1268 USB_OTG_DOEPMSK_NAKM;
1270 USBx_DEVICE->DIEPMSK |= USB_OTG_DIEPMSK_TOM |
1271 USB_OTG_DIEPMSK_XFRCM |
1272 USB_OTG_DIEPMSK_EPDM;
1276 USBx_DEVICE->DCFG &= ~USB_OTG_DCFG_DAD;
1281 __HAL_PCD_CLEAR_FLAG(hpcd, USB_OTG_GINTSTS_USBRST);
1285 if (__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_ENUMDNE))
1293 (uint8_t)hpcd->Init.speed);
1295 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 1296 hpcd->ResetCallback(hpcd);
1301 __HAL_PCD_CLEAR_FLAG(hpcd, USB_OTG_GINTSTS_ENUMDNE);
1305 if (__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_RXFLVL))
1307 USB_MASK_INTERRUPT(hpcd->Instance, USB_OTG_GINTSTS_RXFLVL);
1309 temp = USBx->GRXSTSP;
1311 ep = &hpcd->OUT_ep[temp & USB_OTG_GRXSTSP_EPNUM];
1313 if (((temp & USB_OTG_GRXSTSP_PKTSTS) >> 17) == STS_DATA_UPDT)
1315 if ((temp & USB_OTG_GRXSTSP_BCNT) != 0U)
1318 (uint16_t)((temp & USB_OTG_GRXSTSP_BCNT) >> 4));
1320 ep->
xfer_buff += (temp & USB_OTG_GRXSTSP_BCNT) >> 4;
1321 ep->
xfer_count += (temp & USB_OTG_GRXSTSP_BCNT) >> 4;
1324 else if (((temp & USB_OTG_GRXSTSP_PKTSTS) >> 17) == STS_SETUP_UPDT)
1327 ep->
xfer_count += (temp & USB_OTG_GRXSTSP_BCNT) >> 4;
1333 USB_UNMASK_INTERRUPT(hpcd->Instance, USB_OTG_GINTSTS_RXFLVL);
1337 if (__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_SOF))
1339 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 1340 hpcd->SOFCallback(hpcd);
1345 __HAL_PCD_CLEAR_FLAG(hpcd, USB_OTG_GINTSTS_SOF);
1349 if (__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_IISOIXFR))
1351 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 1352 hpcd->ISOINIncompleteCallback(hpcd, (uint8_t)epnum);
1357 __HAL_PCD_CLEAR_FLAG(hpcd, USB_OTG_GINTSTS_IISOIXFR);
1361 if (__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_PXFR_INCOMPISOOUT))
1363 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 1364 hpcd->ISOOUTIncompleteCallback(hpcd, (uint8_t)epnum);
1369 __HAL_PCD_CLEAR_FLAG(hpcd, USB_OTG_GINTSTS_PXFR_INCOMPISOOUT);
1373 if (__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_SRQINT))
1375 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 1376 hpcd->ConnectCallback(hpcd);
1381 __HAL_PCD_CLEAR_FLAG(hpcd, USB_OTG_GINTSTS_SRQINT);
1385 if (__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_OTGINT))
1387 temp = hpcd->Instance->GOTGINT;
1389 if ((temp & USB_OTG_GOTGINT_SEDET) == USB_OTG_GOTGINT_SEDET)
1391 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 1392 hpcd->DisconnectCallback(hpcd);
1397 hpcd->Instance->GOTGINT |= temp;
1411 if (__HAL_PCD_GET_FLAG(hpcd, USB_ISTR_CTR))
1418 if (__HAL_PCD_GET_FLAG(hpcd, USB_ISTR_RESET))
1420 __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_RESET);
1422 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 1423 hpcd->ResetCallback(hpcd);
1431 if (__HAL_PCD_GET_FLAG(hpcd, USB_ISTR_PMAOVR))
1433 __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_PMAOVR);
1436 if (__HAL_PCD_GET_FLAG(hpcd, USB_ISTR_ERR))
1438 __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_ERR);
1441 if (__HAL_PCD_GET_FLAG(hpcd, USB_ISTR_WKUP))
1443 hpcd->Instance->CNTR &= (uint16_t) ~(USB_CNTR_LPMODE);
1444 hpcd->Instance->CNTR &= (uint16_t) ~(USB_CNTR_FSUSP);
1446 if (hpcd->LPM_State ==
LPM_L1)
1448 hpcd->LPM_State =
LPM_L0;
1449 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 1456 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 1457 hpcd->ResumeCallback(hpcd);
1462 __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_WKUP);
1465 if (__HAL_PCD_GET_FLAG(hpcd, USB_ISTR_SUSP))
1468 hpcd->Instance->CNTR |= USB_CNTR_FSUSP;
1471 __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_SUSP);
1473 hpcd->Instance->CNTR |= USB_CNTR_LPMODE;
1475 if (__HAL_PCD_GET_FLAG(hpcd, USB_ISTR_WKUP) == 0U)
1477 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 1478 hpcd->SuspendCallback(hpcd);
1486 if (__HAL_PCD_GET_FLAG(hpcd, USB_ISTR_L1REQ))
1488 __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_L1REQ);
1489 if (hpcd->LPM_State ==
LPM_L0)
1492 hpcd->Instance->CNTR |= USB_CNTR_LPMODE;
1493 hpcd->Instance->CNTR |= USB_CNTR_FSUSP;
1495 hpcd->LPM_State =
LPM_L1;
1496 hpcd->BESL = ((uint32_t)hpcd->Instance->LPMCSR & USB_LPMCSR_BESL) >> 2;
1497 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 1505 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 1506 hpcd->SuspendCallback(hpcd);
1513 if (__HAL_PCD_GET_FLAG(hpcd, USB_ISTR_SOF))
1515 __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_SOF);
1517 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 1518 hpcd->SOFCallback(hpcd);
1524 if (__HAL_PCD_GET_FLAG(hpcd, USB_ISTR_ESOF))
1527 __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_ESOF);
1730 #if defined (USB_OTG_FS) 1731 USB_OTG_GlobalTypeDef *USBx = hpcd->Instance;
1735 #if defined (USB_OTG_FS) 1736 if (hpcd->Init.battery_charging_enable == 1U)
1739 USBx->GCCFG |= USB_OTG_GCCFG_PWRDWN;
1754 #if defined (USB_OTG_FS) 1755 USB_OTG_GlobalTypeDef *USBx = hpcd->Instance;
1760 #if defined (USB_OTG_FS) 1761 if (hpcd->Init.battery_charging_enable == 1U)
1764 USBx->GCCFG &= ~(USB_OTG_GCCFG_PWRDWN);
1780 hpcd->USB_Address = address;
1795 HAL_StatusTypeDef ret =
HAL_OK;
1798 if ((ep_addr & 0x80U) == 0x80U)
1800 ep = &hpcd->IN_ep[ep_addr & EP_ADDR_MSK];
1805 ep = &hpcd->OUT_ep[ep_addr & EP_ADDR_MSK];
1809 ep->
num = ep_addr & EP_ADDR_MSK;
1813 if (ep->
is_in != 0U)
1819 if (ep_type == EP_TYPE_BULK)
1841 if ((ep_addr & 0x80U) == 0x80U)
1843 ep = &hpcd->IN_ep[ep_addr & EP_ADDR_MSK];
1848 ep = &hpcd->OUT_ep[ep_addr & EP_ADDR_MSK];
1851 ep->
num = ep_addr & EP_ADDR_MSK;
1872 ep = &hpcd->OUT_ep[ep_addr & EP_ADDR_MSK];
1879 ep->
num = ep_addr & EP_ADDR_MSK;
1881 if ((ep_addr & EP_ADDR_MSK) == 0U)
1901 return hpcd->OUT_ep[ep_addr & EP_ADDR_MSK].xfer_count;
1915 ep = &hpcd->IN_ep[ep_addr & EP_ADDR_MSK];
1922 ep->
num = ep_addr & EP_ADDR_MSK;
1924 if ((ep_addr & EP_ADDR_MSK) == 0U)
1946 if (((uint32_t)ep_addr & EP_ADDR_MSK) > hpcd->Init.dev_endpoints)
1951 if ((0x80U & ep_addr) == 0x80U)
1953 ep = &hpcd->IN_ep[ep_addr & EP_ADDR_MSK];
1958 ep = &hpcd->OUT_ep[ep_addr];
1963 ep->
num = ep_addr & EP_ADDR_MSK;
1968 if ((ep_addr & EP_ADDR_MSK) == 0U)
1987 if (((uint32_t)ep_addr & 0x0FU) > hpcd->Init.dev_endpoints)
1992 if ((0x80U & ep_addr) == 0x80U)
1994 ep = &hpcd->IN_ep[ep_addr & EP_ADDR_MSK];
1999 ep = &hpcd->OUT_ep[ep_addr & EP_ADDR_MSK];
2004 ep->
num = ep_addr & EP_ADDR_MSK;
2023 if ((ep_addr & 0x80U) == 0x80U)
2025 (void)
USB_FlushTxFifo(hpcd->Instance, (uint32_t)ep_addr & EP_ADDR_MSK);
2098 #if defined (USB_OTG_FS) 2107 USB_OTG_GlobalTypeDef *USBx = hpcd->Instance;
2108 uint32_t USBx_BASE = (uint32_t)USBx;
2112 uint32_t fifoemptymsk;
2114 ep = &hpcd->IN_ep[epnum];
2128 len32b = (len + 3U) / 4U;
2130 while (((USBx_INEP(epnum)->DTXFSTS & USB_OTG_DTXFSTS_INEPTFSAV) >= len32b) &&
2140 len32b = (len + 3U) / 4U;
2150 fifoemptymsk = (uint32_t)(0x1UL << (epnum & EP_ADDR_MSK));
2151 USBx_DEVICE->DIEPEMPMSK &= ~fifoemptymsk;
2166 USB_OTG_GlobalTypeDef *USBx = hpcd->Instance;
2167 uint32_t USBx_BASE = (uint32_t)USBx;
2168 uint32_t gSNPSiD = *(__IO uint32_t *)(&USBx->CID + 0x1U);
2169 uint32_t DoepintReg = USBx_OUTEP(epnum)->DOEPINT;
2171 if (gSNPSiD == USB_OTG_CORE_ID_310A)
2174 if ((DoepintReg & USB_OTG_DOEPINT_STPKTRX) == USB_OTG_DOEPINT_STPKTRX)
2176 CLEAR_OUT_EP_INTR(epnum, USB_OTG_DOEPINT_STPKTRX);
2180 if ((DoepintReg & USB_OTG_DOEPINT_OTEPSPR) == USB_OTG_DOEPINT_OTEPSPR)
2182 CLEAR_OUT_EP_INTR(epnum, USB_OTG_DOEPINT_OTEPSPR);
2185 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 2186 hpcd->DataOutStageCallback(hpcd, (uint8_t)epnum);
2194 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 2195 hpcd->DataOutStageCallback(hpcd, (uint8_t)epnum);
2213 USB_OTG_GlobalTypeDef *USBx = hpcd->Instance;
2214 uint32_t USBx_BASE = (uint32_t)USBx;
2215 uint32_t gSNPSiD = *(__IO uint32_t *)(&USBx->CID + 0x1U);
2216 uint32_t DoepintReg = USBx_OUTEP(epnum)->DOEPINT;
2219 if ((gSNPSiD == USB_OTG_CORE_ID_310A) &&
2220 ((DoepintReg & USB_OTG_DOEPINT_STPKTRX) == USB_OTG_DOEPINT_STPKTRX))
2222 CLEAR_OUT_EP_INTR(epnum, USB_OTG_DOEPINT_STPKTRX);
2226 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 2227 hpcd->SetupStageCallback(hpcd);
2251 while ((hpcd->Instance->ISTR & USB_ISTR_CTR) != 0U)
2253 wIstr = hpcd->Instance->ISTR;
2255 epindex = (uint8_t)(wIstr & USB_ISTR_EP_ID);
2262 if ((wIstr & USB_ISTR_DIR) == 0U)
2268 PCD_CLEAR_TX_EP_CTR(hpcd->Instance, PCD_ENDP0);
2269 ep = &hpcd->IN_ep[0];
2271 ep->
xfer_count = PCD_GET_EP_TX_CNT(hpcd->Instance, ep->
num);
2275 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 2276 hpcd->DataInStageCallback(hpcd, 0U);
2281 if ((hpcd->USB_Address > 0U) && (ep->
xfer_len == 0U))
2283 hpcd->Instance->DADDR = ((uint16_t)hpcd->USB_Address | USB_DADDR_EF);
2284 hpcd->USB_Address = 0U;
2293 ep = &hpcd->OUT_ep[0];
2294 wEPVal = PCD_GET_ENDPOINT(hpcd->Instance, PCD_ENDP0);
2296 if ((wEPVal & USB_EP_SETUP) != 0U)
2299 ep->
xfer_count = PCD_GET_EP_RX_CNT(hpcd->Instance, ep->
num);
2301 USB_ReadPMA(hpcd->Instance, (uint8_t *)hpcd->Setup,
2305 PCD_CLEAR_RX_EP_CTR(hpcd->Instance, PCD_ENDP0);
2308 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 2309 hpcd->SetupStageCallback(hpcd);
2315 else if ((wEPVal & USB_EP_CTR_RX) != 0U)
2317 PCD_CLEAR_RX_EP_CTR(hpcd->Instance, PCD_ENDP0);
2320 ep->
xfer_count = PCD_GET_EP_RX_CNT(hpcd->Instance, ep->
num);
2330 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 2331 hpcd->DataOutStageCallback(hpcd, 0U);
2337 PCD_SET_EP_RX_CNT(hpcd->Instance, PCD_ENDP0, ep->
maxpacket);
2338 PCD_SET_EP_RX_STATUS(hpcd->Instance, PCD_ENDP0, USB_EP_RX_VALID);
2347 wEPVal = PCD_GET_ENDPOINT(hpcd->Instance, epindex);
2348 if ((wEPVal & USB_EP_CTR_RX) != 0U)
2351 PCD_CLEAR_RX_EP_CTR(hpcd->Instance, epindex);
2352 ep = &hpcd->OUT_ep[epindex];
2355 if (ep->doublebuffer == 0U)
2357 count = (uint16_t)PCD_GET_EP_RX_CNT(hpcd->Instance, ep->
num);
2365 if ((PCD_GET_ENDPOINT(hpcd->Instance, ep->
num) & USB_EP_DTOG_RX) != 0U)
2368 count = (uint16_t)PCD_GET_EP_DBUF0_CNT(hpcd->Instance, ep->
num);
2377 count = (uint16_t)PCD_GET_EP_DBUF1_CNT(hpcd->Instance, ep->
num);
2384 PCD_FreeUserBuffer(hpcd->Instance, ep->
num, 0U);
2390 if ((ep->
xfer_len == 0U) || (count < ep->maxpacket))
2393 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 2394 hpcd->DataOutStageCallback(hpcd, ep->
num);
2406 if ((wEPVal & USB_EP_CTR_TX) != 0U)
2408 ep = &hpcd->IN_ep[epindex];
2411 PCD_CLEAR_TX_EP_CTR(hpcd->Instance, epindex);
2414 ep->
xfer_count = PCD_GET_EP_TX_CNT(hpcd->Instance, ep->
num);
2421 #if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) 2422 hpcd->DataInStageCallback(hpcd, ep->
num);
HAL_StatusTypeDef HAL_PCD_RegisterDataInStageCallback(PCD_HandleTypeDef *hpcd, pPCD_DataInStageCallbackTypeDef pCallback)
Register USB PCD Data IN Stage Callback To be used instead of the weak HAL_PCD_DataInStageCallback() ...
static HAL_StatusTypeDef PCD_EP_OutSetupPacket_int(PCD_HandleTypeDef *hpcd, uint32_t epnum)
process EP OUT setup packet received interrupt.
uint32_t USB_ReadDevOutEPInterrupt(USB_OTG_GlobalTypeDef *USBx, uint8_t epnum)
Returns Device OUT EP Interrupt register.
HAL_StatusTypeDef USB_SetDevAddress(USB_OTG_GlobalTypeDef *USBx, uint8_t address)
USB_SetDevAddress : Stop the usb device mode.
void(* pPCD_CallbackTypeDef)(PCD_HandleTypeDef *hpcd)
void(* pPCD_IsoInIncpltCallbackTypeDef)(PCD_HandleTypeDef *hpcd, uint8_t epnum)
void HAL_PCD_ResumeCallback(PCD_HandleTypeDef *hpcd)
Resume event callback.
HAL_StatusTypeDef USB_DeActivateRemoteWakeup(USB_OTG_GlobalTypeDef *USBx)
USB_DeActivateRemoteWakeup de-active remote wakeup signalling.
HAL_StatusTypeDef USB_EPStartXfer(USB_OTG_GlobalTypeDef *USBx, USB_OTG_EPTypeDef *ep)
USB_EPStartXfer : setup and starts a transfer over an EP.
uint32_t HAL_PCD_EP_GetRxCount(PCD_HandleTypeDef *hpcd, uint8_t ep_addr)
Get Received Data Size.
HAL_StatusTypeDef HAL_PCD_RegisterCallback(PCD_HandleTypeDef *hpcd, HAL_PCD_CallbackIDTypeDef CallbackID, pPCD_CallbackTypeDef pCallback)
Register a User USB PCD Callback To be used instead of the weak predefined callback.
HAL_StatusTypeDef USB_ActivateEndpoint(USB_OTG_GlobalTypeDef *USBx, USB_OTG_EPTypeDef *ep)
Activate and configure an endpoint.
void * USB_ReadPacket(USB_OTG_GlobalTypeDef *USBx, uint8_t *dest, uint16_t len)
USB_ReadPacket : read a packet from the RX FIFO.
HAL_StatusTypeDef HAL_PCD_RegisterIsoOutIncpltCallback(PCD_HandleTypeDef *hpcd, pPCD_IsoOutIncpltCallbackTypeDef pCallback)
Register USB PCD Iso OUT incomplete Callback To be used instead of the weak HAL_PCD_ISOOUTIncompleteC...
HAL_StatusTypeDef USB_DevInit(USB_OTG_GlobalTypeDef *USBx, USB_OTG_CfgTypeDef cfg)
USB_DevInit : Initializes the USB_OTG controller registers for device mode.
void HAL_PCD_MspInit(PCD_HandleTypeDef *hpcd)
Initializes the PCD MSP.
void HAL_PCD_DataOutStageCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum)
Data OUT stage callback.
HAL_StatusTypeDef HAL_PCD_UnRegisterDataInStageCallback(PCD_HandleTypeDef *hpcd)
UnRegister the USB PCD Data IN Stage Callback USB PCD Data OUT Stage Callback is redirected to the we...
PCD_StateTypeDef
PCD State structure definition.
void(* pPCD_DataInStageCallbackTypeDef)(PCD_HandleTypeDef *hpcd, uint8_t epnum)
HAL_StatusTypeDef USB_EP0_OutStart(USB_OTG_GlobalTypeDef *USBx, uint8_t *psetup)
Prepare the EP0 to start the first control setup.
HAL_StatusTypeDef HAL_PCD_EP_ClrStall(PCD_HandleTypeDef *hpcd, uint8_t ep_addr)
Clear a STALL condition over in an endpoint.
HAL_StatusTypeDef HAL_PCD_UnRegisterLpmCallback(PCD_HandleTypeDef *hpcd)
UnRegister the USB PCD LPM Callback USB LPM Callback is redirected to the weak HAL_PCDEx_LPM_Callback...
void HAL_PCD_SOFCallback(PCD_HandleTypeDef *hpcd)
USB Start Of Frame callback.
This file contains all the functions prototypes for the HAL module driver.
void(* pPCD_DataOutStageCallbackTypeDef)(PCD_HandleTypeDef *hpcd, uint8_t epnum)
HAL_StatusTypeDef HAL_PCD_EP_Close(PCD_HandleTypeDef *hpcd, uint8_t ep_addr)
Deactivate an endpoint.
HAL_PCD_CallbackIDTypeDef
struct __PCD_HandleTypeDef else typedef struct endif PCD_HandleTypeDef
PCD Handle Structure definition.
HAL_StatusTypeDef HAL_PCD_UnRegisterBcdCallback(PCD_HandleTypeDef *hpcd)
UnRegister the USB PCD BCD Callback USB BCD Callback is redirected to the weak HAL_PCDEx_BCD_Callback...
void HAL_PCD_ISOINIncompleteCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum)
Incomplete ISO IN callback.
HAL_StatusTypeDef HAL_PCD_DevDisconnect(PCD_HandleTypeDef *hpcd)
Disconnect the USB device.
void(* pPCD_IsoOutIncpltCallbackTypeDef)(PCD_HandleTypeDef *hpcd, uint8_t epnum)
void HAL_PCD_DataInStageCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum)
Data IN stage callback.
HAL_StatusTypeDef HAL_PCD_EP_Transmit(PCD_HandleTypeDef *hpcd, uint8_t ep_addr, uint8_t *pBuf, uint32_t len)
Send an amount of data.
HAL_StatusTypeDef USB_WritePacket(USB_OTG_GlobalTypeDef *USBx, uint8_t *src, uint8_t ch_ep_num, uint16_t len)
USB_WritePacket : Writes a packet into the Tx FIFO associated with the EP/channel.
HAL_StatusTypeDef HAL_PCDEx_ActivateLPM(PCD_HandleTypeDef *hpcd)
Activate LPM feature.
HAL_StatusTypeDef USB_ActivateSetup(USB_OTG_GlobalTypeDef *USBx)
Activate EP0 for Setup transactions.
static HAL_StatusTypeDef PCD_EP_ISR_Handler(PCD_HandleTypeDef *hpcd)
This function handles PCD Endpoint interrupt request.
HAL_StatusTypeDef USB_ActivateRemoteWakeup(USB_OTG_GlobalTypeDef *USBx)
USB_ActivateRemoteWakeup active remote wakeup signalling.
uint32_t USB_ReadDevAllOutEpInterrupt(USB_OTG_GlobalTypeDef *USBx)
USB_ReadDevAllOutEpInterrupt: return the USB device OUT endpoints interrupt status.
void HAL_PCD_ResetCallback(PCD_HandleTypeDef *hpcd)
USB Reset callback.
HAL_StatusTypeDef HAL_PCD_RegisterBcdCallback(PCD_HandleTypeDef *hpcd, pPCD_BcdCallbackTypeDef pCallback)
Register USB PCD BCD Callback To be used instead of the weak HAL_PCDEx_BCD_Callback() predefined call...
void HAL_PCD_ISOOUTIncompleteCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum)
Incomplete ISO OUT callback.
HAL_StatusTypeDef USB_EP0StartXfer(USB_OTG_GlobalTypeDef *USBx, USB_OTG_EPTypeDef *ep)
USB_EP0StartXfer : setup and starts a transfer over the EP 0.
HAL_StatusTypeDef USB_EPClearStall(USB_OTG_GlobalTypeDef *USBx, USB_OTG_EPTypeDef *ep)
USB_EPClearStall : Clear a stall condition over an EP.
static HAL_StatusTypeDef PCD_WriteEmptyTxFifo(PCD_HandleTypeDef *hpcd, uint32_t epnum)
Check FIFO for the next packet to be loaded.
HAL_StatusTypeDef HAL_PCD_DevConnect(PCD_HandleTypeDef *hpcd)
Connect the USB device.
HAL_StatusTypeDef USB_StopDevice(USB_OTG_GlobalTypeDef *USBx)
USB_StopDevice : Stop the usb device mode.
uint32_t USB_ReadDevInEPInterrupt(USB_OTG_GlobalTypeDef *USBx, uint8_t epnum)
Returns Device IN EP Interrupt register.
void HAL_PCD_SetupStageCallback(PCD_HandleTypeDef *hpcd)
Setup stage callback.
HAL_StatusTypeDef HAL_PCD_Start(PCD_HandleTypeDef *hpcd)
Start the USB device.
HAL_StatusTypeDef HAL_PCD_RegisterLpmCallback(PCD_HandleTypeDef *hpcd, pPCD_LpmCallbackTypeDef pCallback)
Register USB PCD LPM Callback To be used instead of the weak HAL_PCDEx_LPM_Callback() predefined call...
HAL_StatusTypeDef HAL_PCD_EP_SetStall(PCD_HandleTypeDef *hpcd, uint8_t ep_addr)
Set a STALL condition over an endpoint.
HAL_StatusTypeDef HAL_PCD_Init(PCD_HandleTypeDef *hpcd)
Initializes the PCD according to the specified parameters in the PCD_InitTypeDef and initialize the a...
HAL_StatusTypeDef USB_CoreInit(USB_OTG_GlobalTypeDef *USBx, USB_OTG_CfgTypeDef cfg)
Initializes the USB Core.
HAL_StatusTypeDef HAL_PCD_EP_Flush(PCD_HandleTypeDef *hpcd, uint8_t ep_addr)
Flush an endpoint.
HAL_StatusTypeDef HAL_PCD_DeInit(PCD_HandleTypeDef *hpcd)
DeInitializes the PCD peripheral.
HAL_StatusTypeDef HAL_PCD_UnRegisterDataOutStageCallback(PCD_HandleTypeDef *hpcd)
UnRegister the USB PCD Data OUT Stage Callback USB PCD Data OUT Stage Callback is redirected to the w...
void HAL_PCD_SuspendCallback(PCD_HandleTypeDef *hpcd)
Suspend event callback.
uint32_t USB_ReadDevAllInEpInterrupt(USB_OTG_GlobalTypeDef *USBx)
USB_ReadDevAllInEpInterrupt: return the USB device IN endpoints interrupt status. ...
void USB_ReadPMA(USB_TypeDef *USBx, uint8_t *pbUsrBuf, uint16_t wPMABufAddr, uint16_t wNBytes)
Copy a buffer from user memory area to packet memory area (PMA)
PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd)
Return the PCD handle state.
static HAL_StatusTypeDef PCD_EP_OutXfrComplete_int(PCD_HandleTypeDef *hpcd, uint32_t epnum)
process EP OUT transfer complete interrupt.
HAL_StatusTypeDef USB_SetTurnaroundTime(USB_OTG_GlobalTypeDef *USBx, uint32_t hclk, uint8_t speed)
Set the USB turnaround time.
HAL_StatusTypeDef USB_FlushRxFifo(USB_OTG_GlobalTypeDef *USBx)
USB_FlushRxFifo : Flush Rx FIFO.
uint32_t HAL_RCC_GetHCLKFreq(void)
Return the HCLK frequency.
HAL_StatusTypeDef USB_DevDisconnect(USB_OTG_GlobalTypeDef *USBx)
USB_DevDisconnect : Disconnect the USB device by disabling the pull-up/pull-down. ...
void HAL_PCDEx_LPM_Callback(PCD_HandleTypeDef *hpcd, PCD_LPM_MsgTypeDef msg)
Send LPM message to user layer callback.
HAL_StatusTypeDef HAL_PCD_UnRegisterIsoInIncpltCallback(PCD_HandleTypeDef *hpcd)
UnRegister the USB PCD Iso IN incomplete Callback USB PCD Iso IN incomplete Callback is redirected to...
HAL_StatusTypeDef HAL_PCD_EP_Receive(PCD_HandleTypeDef *hpcd, uint8_t ep_addr, uint8_t *pBuf, uint32_t len)
Receive an amount of data.
HAL_StatusTypeDef HAL_PCD_Stop(PCD_HandleTypeDef *hpcd)
Stop the USB device.
HAL_StatusTypeDef HAL_PCD_EP_Open(PCD_HandleTypeDef *hpcd, uint8_t ep_addr, uint16_t ep_mps, uint8_t ep_type)
Open and configure an endpoint.
HAL_StatusTypeDef HAL_PCD_RegisterDataOutStageCallback(PCD_HandleTypeDef *hpcd, pPCD_DataOutStageCallbackTypeDef pCallback)
Register USB PCD Data OUT Stage Callback To be used instead of the weak HAL_PCD_DataOutStageCallback(...
void(* pPCD_LpmCallbackTypeDef)(PCD_HandleTypeDef *hpcd, PCD_LPM_MsgTypeDef msg)
HAL_StatusTypeDef HAL_PCD_SetAddress(PCD_HandleTypeDef *hpcd, uint8_t address)
Set the USB Device address.
HAL_StatusTypeDef HAL_PCD_UnRegisterIsoOutIncpltCallback(PCD_HandleTypeDef *hpcd)
UnRegister the USB PCD Iso OUT incomplete Callback USB PCD Iso OUT incomplete Callback is redirected ...
HAL_StatusTypeDef HAL_PCD_ActivateRemoteWakeup(PCD_HandleTypeDef *hpcd)
Activate remote wakeup signalling.
uint8_t USB_GetDevSpeed(USB_OTG_GlobalTypeDef *USBx)
USB_GetDevSpeed Return the Dev Speed.
HAL_StatusTypeDef USB_DevConnect(USB_OTG_GlobalTypeDef *USBx)
USB_DevConnect : Connect the USB device by enabling the pull-up/pull-down.
HAL_StatusTypeDef USB_SetCurrentMode(USB_OTG_GlobalTypeDef *USBx, USB_ModeTypeDef mode)
USB_SetCurrentMode : Set functional mode.
void HAL_PCD_DisconnectCallback(PCD_HandleTypeDef *hpcd)
Disconnection event callback.
HAL_StatusTypeDef USB_FlushTxFifo(USB_OTG_GlobalTypeDef *USBx, uint32_t num)
USB_OTG_FlushTxFifo : Flush a Tx FIFO.
HAL_StatusTypeDef HAL_PCD_DeActivateRemoteWakeup(PCD_HandleTypeDef *hpcd)
De-activate remote wakeup signalling.
HAL_StatusTypeDef USB_DeactivateEndpoint(USB_OTG_GlobalTypeDef *USBx, USB_OTG_EPTypeDef *ep)
De-activate and de-initialize an endpoint.
void HAL_PCD_ConnectCallback(PCD_HandleTypeDef *hpcd)
Connection event callback.
HAL_StatusTypeDef USB_EPSetStall(USB_OTG_GlobalTypeDef *USBx, USB_OTG_EPTypeDef *ep)
USB_EPSetStall : set a stall condition over an EP.
assert_param(IS_RTC_WAKEUP_CLOCK(WakeUpClock))
uint32_t USB_GetMode(USB_OTG_GlobalTypeDef *USBx)
Returns USB core mode.
HAL_StatusTypeDef HAL_PCD_UnRegisterCallback(PCD_HandleTypeDef *hpcd, HAL_PCD_CallbackIDTypeDef CallbackID)
Unregister an USB PCD Callback USB PCD callabck is redirected to the weak predefined callback...
void HAL_PCDEx_BCD_Callback(PCD_HandleTypeDef *hpcd, PCD_BCD_MsgTypeDef msg)
Send BatteryCharging message to user layer callback.
void(* pPCD_BcdCallbackTypeDef)(PCD_HandleTypeDef *hpcd, PCD_BCD_MsgTypeDef msg)
void HAL_PCD_IRQHandler(PCD_HandleTypeDef *hpcd)
Handles PCD interrupt request.
void HAL_PCD_MspDeInit(PCD_HandleTypeDef *hpcd)
DeInitializes PCD MSP.
HAL_StatusTypeDef HAL_PCD_RegisterIsoInIncpltCallback(PCD_HandleTypeDef *hpcd, pPCD_IsoInIncpltCallbackTypeDef pCallback)
Register USB PCD Iso IN incomplete Callback To be used instead of the weak HAL_PCD_ISOINIncompleteCal...