Initial commit

Dependencies:   FastPWM

Committer:
lypinator
Date:
Wed Sep 16 01:11:49 2020 +0000
Revision:
0:bb348c97df44
Added PWM

Who changed what in which revision?

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