39 #ifndef __STM32F4xx_HAL_PCD_H 40 #define __STM32F4xx_HAL_PCD_H 45 #if defined(STM32F405xx) || defined(STM32F415xx) || defined(STM32F407xx) || defined(STM32F417xx) || \ 46 defined(STM32F427xx) || defined(STM32F437xx) || defined(STM32F429xx) || defined(STM32F439xx) || \ 47 defined(STM32F401xC) || defined(STM32F401xE) || defined(STM32F411xE) || defined(STM32F446xx) || \ 48 defined(STM32F469xx) || defined(STM32F479xx) || defined(STM32F412Zx) || defined(STM32F412Vx) || \ 49 defined(STM32F412Rx) || defined(STM32F412Cx) 71 HAL_PCD_STATE_RESET = 0x00U,
72 HAL_PCD_STATE_READY = 0x01U,
73 HAL_PCD_STATE_ERROR = 0x02U,
74 HAL_PCD_STATE_BUSY = 0x03U,
75 HAL_PCD_STATE_TIMEOUT = 0x04U
78 #ifdef USB_OTG_GLPMCFG_LPMEN 86 }PCD_LPM_StateTypeDef;
90 typedef USB_OTG_CfgTypeDef PCD_InitTypeDef;
91 typedef USB_OTG_EPTypeDef PCD_EPTypeDef ;
98 PCD_TypeDef *Instance;
100 PCD_EPTypeDef IN_ep[15];
101 PCD_EPTypeDef OUT_ep[15];
103 __IO PCD_StateTypeDef State;
105 #ifdef USB_OTG_GLPMCFG_LPMEN 106 PCD_LPM_StateTypeDef LPM_State;
111 #ifdef USB_OTG_GCCFG_BCDEN 112 uint32_t battery_charging_active;
133 #define PCD_SPEED_HIGH 0U 134 #define PCD_SPEED_HIGH_IN_FULL 1U 135 #define PCD_SPEED_FULL 2U 143 #define PCD_PHY_ULPI 1U 144 #define PCD_PHY_EMBEDDED 2U 152 #ifndef USBD_HS_TRDT_VALUE 153 #define USBD_HS_TRDT_VALUE 9U 155 #ifndef USBD_FS_TRDT_VALUE 156 #define USBD_FS_TRDT_VALUE 5U 171 #define __HAL_PCD_ENABLE(__HANDLE__) USB_EnableGlobalInt ((__HANDLE__)->Instance) 172 #define __HAL_PCD_DISABLE(__HANDLE__) USB_DisableGlobalInt ((__HANDLE__)->Instance) 174 #define __HAL_PCD_GET_FLAG(__HANDLE__, __INTERRUPT__) ((USB_ReadInterrupts((__HANDLE__)->Instance) & (__INTERRUPT__)) == (__INTERRUPT__)) 175 #define __HAL_PCD_CLEAR_FLAG(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->GINTSTS) &= (__INTERRUPT__)) 176 #define __HAL_PCD_IS_INVALID_INTERRUPT(__HANDLE__) (USB_ReadInterrupts((__HANDLE__)->Instance) == 0U) 178 #define __HAL_PCD_UNGATE_PHYCLOCK(__HANDLE__) *(__IO uint32_t *)((uint32_t)((__HANDLE__)->Instance) + USB_OTG_PCGCCTL_BASE) &= \ 179 ~(USB_OTG_PCGCCTL_STOPCLK) 181 #define __HAL_PCD_GATE_PHYCLOCK(__HANDLE__) *(__IO uint32_t *)((uint32_t)((__HANDLE__)->Instance) + USB_OTG_PCGCCTL_BASE) |= USB_OTG_PCGCCTL_STOPCLK 183 #define __HAL_PCD_IS_PHY_SUSPENDED(__HANDLE__) ((*(__IO uint32_t *)((uint32_t)((__HANDLE__)->Instance) + USB_OTG_PCGCCTL_BASE))&0x10U) 185 #define USB_OTG_FS_WAKEUP_EXTI_RISING_EDGE ((uint32_t)0x08U) 186 #define USB_OTG_FS_WAKEUP_EXTI_FALLING_EDGE ((uint32_t)0x0CU) 187 #define USB_OTG_FS_WAKEUP_EXTI_RISING_FALLING_EDGE ((uint32_t)0x10U) 189 #define USB_OTG_HS_WAKEUP_EXTI_RISING_EDGE ((uint32_t)0x08U) 190 #define USB_OTG_HS_WAKEUP_EXTI_FALLING_EDGE ((uint32_t)0x0CU) 191 #define USB_OTG_HS_WAKEUP_EXTI_RISING_FALLING_EDGE ((uint32_t)0x10U) 193 #define USB_OTG_HS_WAKEUP_EXTI_LINE ((uint32_t)0x00100000U) 194 #define USB_OTG_FS_WAKEUP_EXTI_LINE ((uint32_t)0x00040000U) 196 #define __HAL_USB_OTG_HS_WAKEUP_EXTI_ENABLE_IT() EXTI->IMR |= (USB_OTG_HS_WAKEUP_EXTI_LINE) 197 #define __HAL_USB_OTG_HS_WAKEUP_EXTI_DISABLE_IT() EXTI->IMR &= ~(USB_OTG_HS_WAKEUP_EXTI_LINE) 198 #define __HAL_USB_OTG_HS_WAKEUP_EXTI_GET_FLAG() EXTI->PR & (USB_OTG_HS_WAKEUP_EXTI_LINE) 199 #define __HAL_USB_OTG_HS_WAKEUP_EXTI_CLEAR_FLAG() EXTI->PR = (USB_OTG_HS_WAKEUP_EXTI_LINE) 201 #define __HAL_USB_OTG_HS_WAKEUP_EXTI_ENABLE_RISING_EDGE() do{EXTI->FTSR &= ~(USB_OTG_HS_WAKEUP_EXTI_LINE);\ 202 EXTI->RTSR |= USB_OTG_HS_WAKEUP_EXTI_LINE;\ 205 #define __HAL_USB_OTG_HS_WAKEUP_EXTI_ENABLE_FALLING_EDGE() do{EXTI->FTSR |= (USB_OTG_HS_WAKEUP_EXTI_LINE);\ 206 EXTI->RTSR &= ~(USB_OTG_HS_WAKEUP_EXTI_LINE);\ 209 #define __HAL_USB_OTG_HS_WAKEUP_EXTI_ENABLE_RISING_FALLING_EDGE() do{EXTI->RTSR &= ~(USB_OTG_HS_WAKEUP_EXTI_LINE);\ 210 EXTI->FTSR &= ~(USB_OTG_HS_WAKEUP_EXTI_LINE);\ 211 EXTI->RTSR |= USB_OTG_HS_WAKEUP_EXTI_LINE;\ 212 EXTI->FTSR |= USB_OTG_HS_WAKEUP_EXTI_LINE;\ 215 #define __HAL_USB_OTG_HS_WAKEUP_EXTI_GENERATE_SWIT() (EXTI->SWIER |= USB_OTG_FS_WAKEUP_EXTI_LINE) 217 #define __HAL_USB_OTG_FS_WAKEUP_EXTI_ENABLE_IT() EXTI->IMR |= USB_OTG_FS_WAKEUP_EXTI_LINE 218 #define __HAL_USB_OTG_FS_WAKEUP_EXTI_DISABLE_IT() EXTI->IMR &= ~(USB_OTG_FS_WAKEUP_EXTI_LINE) 219 #define __HAL_USB_OTG_FS_WAKEUP_EXTI_GET_FLAG() EXTI->PR & (USB_OTG_FS_WAKEUP_EXTI_LINE) 220 #define __HAL_USB_OTG_FS_WAKEUP_EXTI_CLEAR_FLAG() EXTI->PR = USB_OTG_FS_WAKEUP_EXTI_LINE 222 #define __HAL_USB_OTG_FS_WAKEUP_EXTI_ENABLE_RISING_EDGE() do{EXTI->FTSR &= ~(USB_OTG_FS_WAKEUP_EXTI_LINE);\ 223 EXTI->RTSR |= USB_OTG_FS_WAKEUP_EXTI_LINE;\ 226 #define __HAL_USB_OTG_FS_WAKEUP_EXTI_ENABLE_FALLING_EDGE() do{EXTI->FTSR |= (USB_OTG_FS_WAKEUP_EXTI_LINE);\ 227 EXTI->RTSR &= ~(USB_OTG_FS_WAKEUP_EXTI_LINE);\ 230 #define __HAL_USB_OTG_FS_WAKEUP_EXTI_ENABLE_RISING_FALLING_EDGE() do{EXTI->RTSR &= ~(USB_OTG_FS_WAKEUP_EXTI_LINE);\ 231 EXTI->FTSR &= ~(USB_OTG_FS_WAKEUP_EXTI_LINE);\ 232 EXTI->RTSR |= USB_OTG_FS_WAKEUP_EXTI_LINE;\ 233 EXTI->FTSR |= USB_OTG_FS_WAKEUP_EXTI_LINE;\ 236 #define __HAL_USB_OTG_FS_WAKEUP_EXTI_GENERATE_SWIT() (EXTI->SWIER |= USB_OTG_FS_WAKEUP_EXTI_LINE) 252 void HAL_PCD_MspInit(PCD_HandleTypeDef *hpcd);
253 void HAL_PCD_MspDeInit(PCD_HandleTypeDef *hpcd);
266 void HAL_PCD_IRQHandler(PCD_HandleTypeDef *hpcd);
268 void HAL_PCD_DataOutStageCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum);
269 void HAL_PCD_DataInStageCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum);
270 void HAL_PCD_SetupStageCallback(PCD_HandleTypeDef *hpcd);
271 void HAL_PCD_SOFCallback(PCD_HandleTypeDef *hpcd);
272 void HAL_PCD_ResetCallback(PCD_HandleTypeDef *hpcd);
273 void HAL_PCD_SuspendCallback(PCD_HandleTypeDef *hpcd);
274 void HAL_PCD_ResumeCallback(PCD_HandleTypeDef *hpcd);
275 void HAL_PCD_ISOOUTIncompleteCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum);
276 void HAL_PCD_ISOINIncompleteCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum);
277 void HAL_PCD_ConnectCallback(PCD_HandleTypeDef *hpcd);
278 void HAL_PCD_DisconnectCallback(PCD_HandleTypeDef *hpcd);
290 HAL_StatusTypeDef HAL_PCD_EP_Open(PCD_HandleTypeDef *hpcd, uint8_t ep_addr, uint16_t ep_mps, uint8_t ep_type);
292 HAL_StatusTypeDef HAL_PCD_EP_Receive(PCD_HandleTypeDef *hpcd, uint8_t ep_addr, uint8_t *pBuf, uint32_t len);
293 HAL_StatusTypeDef HAL_PCD_EP_Transmit(PCD_HandleTypeDef *hpcd, uint8_t ep_addr, uint8_t *pBuf, uint32_t len);
294 uint16_t HAL_PCD_EP_GetRxCount(PCD_HandleTypeDef *hpcd, uint8_t ep_addr);
308 PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
Header file of PCD HAL module.
__USB_OTG_Core_register
Definition: stm32f401xc.h:543
HAL_StatusTypeDef
HAL Status structures definition.
Definition: stm32f4xx_hal_def.h:57
#define __IO
Definition: core_cm0.h:213
HAL_LockTypeDef
HAL Lock structures definition.
Definition: stm32f4xx_hal_def.h:68
Header file of USB Core HAL module.