comparison Common/Drivers/STM32F4xx_HAL_Driver/Inc/stm32f4xx_hal_pcd.h @ 160:e3ca52b8e7fa

Merge with FlipDisplay
author heinrichsweikamp
date Thu, 07 Mar 2019 15:06:43 +0100
parents c78bcbd5deda
children
comparison
equal deleted inserted replaced
80:cc2bb7bb8456 160:e3ca52b8e7fa
1 /**
2 ******************************************************************************
3 * @file stm32f4xx_hal_pcd.h
4 * @author MCD Application Team
5 * @brief Header file of PCD HAL module.
6 ******************************************************************************
7 * @attention
8 *
9 * <h2><center>&copy; COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
10 *
11 * Redistribution and use in source and binary forms, with or without modification,
12 * are permitted provided that the following conditions are met:
13 * 1. Redistributions of source code must retain the above copyright notice,
14 * this list of conditions and the following disclaimer.
15 * 2. Redistributions in binary form must reproduce the above copyright notice,
16 * this list of conditions and the following disclaimer in the documentation
17 * and/or other materials provided with the distribution.
18 * 3. Neither the name of STMicroelectronics nor the names of its contributors
19 * may be used to endorse or promote products derived from this software
20 * without specific prior written permission.
21 *
22 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
23 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
25 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
26 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
27 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
28 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
30 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 *
33 ******************************************************************************
34 */
35
36 /* Define to prevent recursive inclusion -------------------------------------*/
37 #ifndef __STM32F4xx_HAL_PCD_H
38 #define __STM32F4xx_HAL_PCD_H
39
40 #ifdef __cplusplus
41 extern "C" {
42 #endif
43 #if defined(STM32F405xx) || defined(STM32F415xx) || defined(STM32F407xx) || defined(STM32F417xx) || \
44 defined(STM32F427xx) || defined(STM32F437xx) || defined(STM32F429xx) || defined(STM32F439xx) || \
45 defined(STM32F401xC) || defined(STM32F401xE) || defined(STM32F411xE) || defined(STM32F446xx) || \
46 defined(STM32F469xx) || defined(STM32F479xx) || defined(STM32F412Zx) || defined(STM32F412Vx) || \
47 defined(STM32F412Rx) || defined(STM32F412Cx) || defined(STM32F413xx) || defined(STM32F423xx)
48 /* Includes ------------------------------------------------------------------*/
49 #include "stm32f4xx_ll_usb.h"
50
51 /** @addtogroup STM32F4xx_HAL_Driver
52 * @{
53 */
54
55 /** @addtogroup PCD
56 * @{
57 */
58
59 /* Exported types ------------------------------------------------------------*/
60 /** @defgroup PCD_Exported_Types PCD Exported Types
61 * @{
62 */
63
64 /**
65 * @brief PCD State structure definition
66 */
67 typedef enum
68 {
69 HAL_PCD_STATE_RESET = 0x00U,
70 HAL_PCD_STATE_READY = 0x01U,
71 HAL_PCD_STATE_ERROR = 0x02U,
72 HAL_PCD_STATE_BUSY = 0x03U,
73 HAL_PCD_STATE_TIMEOUT = 0x04U
74 } PCD_StateTypeDef;
75
76 #ifdef USB_OTG_GLPMCFG_LPMEN
77 /* Device LPM suspend state */
78 typedef enum
79 {
80 LPM_L0 = 0x00U, /* on */
81 LPM_L1 = 0x01U, /* LPM L1 sleep */
82 LPM_L2 = 0x02U, /* suspend */
83 LPM_L3 = 0x03U /* off */
84 }PCD_LPM_StateTypeDef;
85 #endif /* USB_OTG_GLPMCFG_LPMEN */
86
87 typedef USB_OTG_GlobalTypeDef PCD_TypeDef;
88 typedef USB_OTG_CfgTypeDef PCD_InitTypeDef;
89 typedef USB_OTG_EPTypeDef PCD_EPTypeDef ;
90
91 /**
92 * @brief PCD Handle Structure definition
93 */
94 typedef struct
95 {
96 PCD_TypeDef *Instance; /*!< Register base address */
97 PCD_InitTypeDef Init; /*!< PCD required parameters */
98 PCD_EPTypeDef IN_ep[16U]; /*!< IN endpoint parameters */
99 PCD_EPTypeDef OUT_ep[16U]; /*!< OUT endpoint parameters */
100 HAL_LockTypeDef Lock; /*!< PCD peripheral status */
101 __IO PCD_StateTypeDef State; /*!< PCD communication state */
102 uint32_t Setup[12U]; /*!< Setup packet buffer */
103 #ifdef USB_OTG_GLPMCFG_LPMEN
104 PCD_LPM_StateTypeDef LPM_State; /*!< LPM State */
105 uint32_t BESL;
106 uint32_t lpm_active; /*!< Enable or disable the Link Power Management .
107 This parameter can be set to ENABLE or DISABLE */
108 #endif /* USB_OTG_GLPMCFG_LPMEN */
109 #ifdef USB_OTG_GCCFG_BCDEN
110 uint32_t battery_charging_active; /*!< Enable or disable Battery charging.
111 This parameter can be set to ENABLE or DISABLE */
112 #endif /* USB_OTG_GCCFG_BCDEN */
113 void *pData; /*!< Pointer to upper stack Handler */
114 } PCD_HandleTypeDef;
115
116 /**
117 * @}
118 */
119
120 /* Include PCD HAL Extension module */
121 #include "stm32f4xx_hal_pcd_ex.h"
122
123 /* Exported constants --------------------------------------------------------*/
124 /** @defgroup PCD_Exported_Constants PCD Exported Constants
125 * @{
126 */
127
128 /** @defgroup PCD_Speed PCD Speed
129 * @{
130 */
131 #define PCD_SPEED_HIGH 0U
132 #define PCD_SPEED_HIGH_IN_FULL 1U
133 #define PCD_SPEED_FULL 2U
134 /**
135 * @}
136 */
137
138 /** @defgroup PCD_PHY_Module PCD PHY Module
139 * @{
140 */
141 #define PCD_PHY_ULPI 1U
142 #define PCD_PHY_EMBEDDED 2U
143 /**
144 * @}
145 */
146
147 /** @defgroup PCD_Turnaround_Timeout Turnaround Timeout Value
148 * @{
149 */
150 #ifndef USBD_HS_TRDT_VALUE
151 #define USBD_HS_TRDT_VALUE 9U
152 #endif /* USBD_HS_TRDT_VALUE */
153 #ifndef USBD_FS_TRDT_VALUE
154 #define USBD_FS_TRDT_VALUE 5U
155 #endif /* USBD_FS_TRDT_VALUE */
156 /**
157 * @}
158 */
159
160 /**
161 * @}
162 */
163
164 /* Exported macros -----------------------------------------------------------*/
165 /** @defgroup PCD_Exported_Macros PCD Exported Macros
166 * @brief macros to handle interrupts and specific clock configurations
167 * @{
168 */
169 #define __HAL_PCD_ENABLE(__HANDLE__) USB_EnableGlobalInt ((__HANDLE__)->Instance)
170 #define __HAL_PCD_DISABLE(__HANDLE__) USB_DisableGlobalInt ((__HANDLE__)->Instance)
171
172 #define __HAL_PCD_GET_FLAG(__HANDLE__, __INTERRUPT__) ((USB_ReadInterrupts((__HANDLE__)->Instance) & (__INTERRUPT__)) == (__INTERRUPT__))
173 #define __HAL_PCD_CLEAR_FLAG(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->GINTSTS) &= (__INTERRUPT__))
174 #define __HAL_PCD_IS_INVALID_INTERRUPT(__HANDLE__) (USB_ReadInterrupts((__HANDLE__)->Instance) == 0U)
175
176 #define __HAL_PCD_UNGATE_PHYCLOCK(__HANDLE__) *(__IO uint32_t *)((uint32_t)((__HANDLE__)->Instance) + USB_OTG_PCGCCTL_BASE) &= \
177 ~(USB_OTG_PCGCCTL_STOPCLK)
178
179 #define __HAL_PCD_GATE_PHYCLOCK(__HANDLE__) *(__IO uint32_t *)((uint32_t)((__HANDLE__)->Instance) + USB_OTG_PCGCCTL_BASE) |= USB_OTG_PCGCCTL_STOPCLK
180
181 #define __HAL_PCD_IS_PHY_SUSPENDED(__HANDLE__) ((*(__IO uint32_t *)((uint32_t)((__HANDLE__)->Instance) + USB_OTG_PCGCCTL_BASE))&0x10U)
182
183 #define USB_OTG_FS_WAKEUP_EXTI_RISING_EDGE 0x08U
184 #define USB_OTG_FS_WAKEUP_EXTI_FALLING_EDGE 0x0CU
185 #define USB_OTG_FS_WAKEUP_EXTI_RISING_FALLING_EDGE 0x10U
186
187 #define USB_OTG_HS_WAKEUP_EXTI_RISING_EDGE 0x08U
188 #define USB_OTG_HS_WAKEUP_EXTI_FALLING_EDGE 0x0CU
189 #define USB_OTG_HS_WAKEUP_EXTI_RISING_FALLING_EDGE 0x10U
190
191 #define USB_OTG_HS_WAKEUP_EXTI_LINE 0x00100000U /*!< External interrupt line 20 Connected to the USB HS EXTI Line */
192 #define USB_OTG_FS_WAKEUP_EXTI_LINE 0x00040000U /*!< External interrupt line 18 Connected to the USB FS EXTI Line */
193
194 #define __HAL_USB_OTG_HS_WAKEUP_EXTI_ENABLE_IT() EXTI->IMR |= (USB_OTG_HS_WAKEUP_EXTI_LINE)
195 #define __HAL_USB_OTG_HS_WAKEUP_EXTI_DISABLE_IT() EXTI->IMR &= ~(USB_OTG_HS_WAKEUP_EXTI_LINE)
196 #define __HAL_USB_OTG_HS_WAKEUP_EXTI_GET_FLAG() EXTI->PR & (USB_OTG_HS_WAKEUP_EXTI_LINE)
197 #define __HAL_USB_OTG_HS_WAKEUP_EXTI_CLEAR_FLAG() EXTI->PR = (USB_OTG_HS_WAKEUP_EXTI_LINE)
198
199 #define __HAL_USB_OTG_HS_WAKEUP_EXTI_ENABLE_RISING_EDGE() do{EXTI->FTSR &= ~(USB_OTG_HS_WAKEUP_EXTI_LINE);\
200 EXTI->RTSR |= USB_OTG_HS_WAKEUP_EXTI_LINE;\
201 }while(0U)
202
203 #define __HAL_USB_OTG_HS_WAKEUP_EXTI_ENABLE_FALLING_EDGE() do{EXTI->FTSR |= (USB_OTG_HS_WAKEUP_EXTI_LINE);\
204 EXTI->RTSR &= ~(USB_OTG_HS_WAKEUP_EXTI_LINE);\
205 }while(0U)
206
207 #define __HAL_USB_OTG_HS_WAKEUP_EXTI_ENABLE_RISING_FALLING_EDGE() do{EXTI->RTSR &= ~(USB_OTG_HS_WAKEUP_EXTI_LINE);\
208 EXTI->FTSR &= ~(USB_OTG_HS_WAKEUP_EXTI_LINE);\
209 EXTI->RTSR |= USB_OTG_HS_WAKEUP_EXTI_LINE;\
210 EXTI->FTSR |= USB_OTG_HS_WAKEUP_EXTI_LINE;\
211 }while(0U)
212
213 #define __HAL_USB_OTG_HS_WAKEUP_EXTI_GENERATE_SWIT() (EXTI->SWIER |= USB_OTG_FS_WAKEUP_EXTI_LINE)
214
215 #define __HAL_USB_OTG_FS_WAKEUP_EXTI_ENABLE_IT() EXTI->IMR |= USB_OTG_FS_WAKEUP_EXTI_LINE
216 #define __HAL_USB_OTG_FS_WAKEUP_EXTI_DISABLE_IT() EXTI->IMR &= ~(USB_OTG_FS_WAKEUP_EXTI_LINE)
217 #define __HAL_USB_OTG_FS_WAKEUP_EXTI_GET_FLAG() EXTI->PR & (USB_OTG_FS_WAKEUP_EXTI_LINE)
218 #define __HAL_USB_OTG_FS_WAKEUP_EXTI_CLEAR_FLAG() EXTI->PR = USB_OTG_FS_WAKEUP_EXTI_LINE
219
220 #define __HAL_USB_OTG_FS_WAKEUP_EXTI_ENABLE_RISING_EDGE() do{EXTI->FTSR &= ~(USB_OTG_FS_WAKEUP_EXTI_LINE);\
221 EXTI->RTSR |= USB_OTG_FS_WAKEUP_EXTI_LINE;\
222 }while(0U)
223
224 #define __HAL_USB_OTG_FS_WAKEUP_EXTI_ENABLE_FALLING_EDGE() do{EXTI->FTSR |= (USB_OTG_FS_WAKEUP_EXTI_LINE);\
225 EXTI->RTSR &= ~(USB_OTG_FS_WAKEUP_EXTI_LINE);\
226 }while(0U)
227
228 #define __HAL_USB_OTG_FS_WAKEUP_EXTI_ENABLE_RISING_FALLING_EDGE() do{EXTI->RTSR &= ~(USB_OTG_FS_WAKEUP_EXTI_LINE);\
229 EXTI->FTSR &= ~(USB_OTG_FS_WAKEUP_EXTI_LINE);\
230 EXTI->RTSR |= USB_OTG_FS_WAKEUP_EXTI_LINE;\
231 EXTI->FTSR |= USB_OTG_FS_WAKEUP_EXTI_LINE;\
232 }while(0U)
233
234 #define __HAL_USB_OTG_FS_WAKEUP_EXTI_GENERATE_SWIT() (EXTI->SWIER |= USB_OTG_FS_WAKEUP_EXTI_LINE)
235 /**
236 * @}
237 */
238
239 /* Exported functions --------------------------------------------------------*/
240 /** @addtogroup PCD_Exported_Functions PCD Exported Functions
241 * @{
242 */
243
244 /* Initialization/de-initialization functions ********************************/
245 /** @addtogroup PCD_Exported_Functions_Group1 Initialization and de-initialization functions
246 * @{
247 */
248 HAL_StatusTypeDef HAL_PCD_Init(PCD_HandleTypeDef *hpcd);
249 HAL_StatusTypeDef HAL_PCD_DeInit(PCD_HandleTypeDef *hpcd);
250 void HAL_PCD_MspInit(PCD_HandleTypeDef *hpcd);
251 void HAL_PCD_MspDeInit(PCD_HandleTypeDef *hpcd);
252 /**
253 * @}
254 */
255
256 /* I/O operation functions ***************************************************/
257 /* Non-Blocking mode: Interrupt */
258 /** @addtogroup PCD_Exported_Functions_Group2 Input and Output operation functions
259 * @{
260 */
261 /* Non-Blocking mode: Interrupt */
262 HAL_StatusTypeDef HAL_PCD_Start(PCD_HandleTypeDef *hpcd);
263 HAL_StatusTypeDef HAL_PCD_Stop(PCD_HandleTypeDef *hpcd);
264 void HAL_PCD_IRQHandler(PCD_HandleTypeDef *hpcd);
265
266 void HAL_PCD_DataOutStageCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum);
267 void HAL_PCD_DataInStageCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum);
268 void HAL_PCD_SetupStageCallback(PCD_HandleTypeDef *hpcd);
269 void HAL_PCD_SOFCallback(PCD_HandleTypeDef *hpcd);
270 void HAL_PCD_ResetCallback(PCD_HandleTypeDef *hpcd);
271 void HAL_PCD_SuspendCallback(PCD_HandleTypeDef *hpcd);
272 void HAL_PCD_ResumeCallback(PCD_HandleTypeDef *hpcd);
273 void HAL_PCD_ISOOUTIncompleteCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum);
274 void HAL_PCD_ISOINIncompleteCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum);
275 void HAL_PCD_ConnectCallback(PCD_HandleTypeDef *hpcd);
276 void HAL_PCD_DisconnectCallback(PCD_HandleTypeDef *hpcd);
277 /**
278 * @}
279 */
280
281 /* Peripheral Control functions **********************************************/
282 /** @addtogroup PCD_Exported_Functions_Group3 Peripheral Control functions
283 * @{
284 */
285 HAL_StatusTypeDef HAL_PCD_DevConnect(PCD_HandleTypeDef *hpcd);
286 HAL_StatusTypeDef HAL_PCD_DevDisconnect(PCD_HandleTypeDef *hpcd);
287 HAL_StatusTypeDef HAL_PCD_SetAddress(PCD_HandleTypeDef *hpcd, uint8_t address);
288 HAL_StatusTypeDef HAL_PCD_EP_Open(PCD_HandleTypeDef *hpcd, uint8_t ep_addr, uint16_t ep_mps, uint8_t ep_type);
289 HAL_StatusTypeDef HAL_PCD_EP_Close(PCD_HandleTypeDef *hpcd, uint8_t ep_addr);
290 HAL_StatusTypeDef HAL_PCD_EP_Receive(PCD_HandleTypeDef *hpcd, uint8_t ep_addr, uint8_t *pBuf, uint32_t len);
291 HAL_StatusTypeDef HAL_PCD_EP_Transmit(PCD_HandleTypeDef *hpcd, uint8_t ep_addr, uint8_t *pBuf, uint32_t len);
292 uint16_t HAL_PCD_EP_GetRxCount(PCD_HandleTypeDef *hpcd, uint8_t ep_addr);
293 HAL_StatusTypeDef HAL_PCD_EP_SetStall(PCD_HandleTypeDef *hpcd, uint8_t ep_addr);
294 HAL_StatusTypeDef HAL_PCD_EP_ClrStall(PCD_HandleTypeDef *hpcd, uint8_t ep_addr);
295 HAL_StatusTypeDef HAL_PCD_EP_Flush(PCD_HandleTypeDef *hpcd, uint8_t ep_addr);
296 HAL_StatusTypeDef HAL_PCD_ActivateRemoteWakeup(PCD_HandleTypeDef *hpcd);
297 HAL_StatusTypeDef HAL_PCD_DeActivateRemoteWakeup(PCD_HandleTypeDef *hpcd);
298 /**
299 * @}
300 */
301
302 /* Peripheral State functions ************************************************/
303 /** @addtogroup PCD_Exported_Functions_Group4 Peripheral State functions
304 * @{
305 */
306 PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd);
307 /**
308 * @}
309 */
310
311 /**
312 * @}
313 */
314
315 /* Private macros ------------------------------------------------------------*/
316 /** @defgroup PCD_Private_Macros PCD Private Macros
317 * @{
318 */
319
320 /**
321 * @}
322 */
323
324 /**
325 * @}
326 */
327
328 /**
329 * @}
330 */
331 #endif /* STM32F405xx || STM32F415xx || STM32F407xx || STM32F417xx || STM32F427xx || STM32F437xx || STM32F429xx || STM32F439xx ||
332 STM32F401xC || STM32F401xE || STM32F411xE || STM32F446xx || STM32F469xx || STM32F479xx || STM32F412Zx || STM32F412Rx ||
333 STM32F412Vx || STM32F412Cx || STM32F413xx || STM32F423xx */
334 #ifdef __cplusplus
335 }
336 #endif
337
338
339 #endif /* __STM32F4xx_HAL_PCD_H */
340
341 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/