mbed official / mbed

Dependents:   hello SerialTestv11 SerialTestv12 Sierpinski ... more

Committer:
Kojto
Date:
Thu Jul 07 14:34:11 2016 +0100
Revision:
122:f9eeca106725
Parent:
112:6f327212ef96
Release 122 of the mbed library

Changes:
- new targets - Nucleo L432KC, Beetle, Nucleo F446ZE, Nucleo L011K4
- Thread safety addition - mbed API should contain a statement about thread safety
- critical section API addition
- CAS API (core_util_atomic_incr/decr)
- DEVICE_ are generated from targets.json file, device.h deprecated
- Callback replaces FunctionPointer to provide std like interface
- mbed HAL API docs improvements
- toolchain - prexif attributes with MBED_
- add new attributes - packed, weak, forcedinline, align
- target.json - contains targets definitions
- ST - L1XX - Cube update to 1.5
- SPI clock selection fix (clock from APB domain)
- F7 - Cube update v1.4.0
- L0 - baudrate init fix
- L1 - Cube update v1.5
- F3 - baudrate init fix, 3 targets CAN support
- F4 - Cube update v1.12.0, 3 targets CAN support
- L4XX - Cube update v1.5.1
- F0 - update Cube to v1.5.0
- L4 - 2 targets (L476RG/VG) CAN support
- NXP - pwm clock fix for KSDK2 MCU
- LPC2368 - remove ARM toolchain support - due to regression
- KSDK2 - fix SPI , I2C address and repeat start
- Silabs - some fixes backported from mbed 3
- Renesas - RZ_A1H - SystemCoreClockUpdate addition

Who changed what in which revision?

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