Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Fork of mbed-dev by
targets/cmsis/TARGET_STM/TARGET_STM32F1/stm32f1xx_hal_pcd.c@0:9b334a45a8ff, 2015-10-01 (annotated)
- Committer:
- bogdanm
- Date:
- Thu Oct 01 15:25:22 2015 +0300
- Revision:
- 0:9b334a45a8ff
- Child:
- 48:bedbbf74271f
Initial commit on mbed-dev
Replaces mbed-src (now inactive)
Who changed what in which revision?
| User | Revision | Line number | New contents of line |
|---|---|---|---|
| bogdanm | 0:9b334a45a8ff | 1 | /** |
| bogdanm | 0:9b334a45a8ff | 2 | ****************************************************************************** |
| bogdanm | 0:9b334a45a8ff | 3 | * @file stm32f1xx_hal_pcd.c |
| bogdanm | 0:9b334a45a8ff | 4 | * @author MCD Application Team |
| bogdanm | 0:9b334a45a8ff | 5 | * @version V1.0.0 |
| bogdanm | 0:9b334a45a8ff | 6 | * @date 15-December-2014 |
| bogdanm | 0:9b334a45a8ff | 7 | * @brief PCD HAL module driver. |
| bogdanm | 0:9b334a45a8ff | 8 | * This file provides firmware functions to manage the following |
| bogdanm | 0:9b334a45a8ff | 9 | * functionalities of the USB Peripheral Controller: |
| bogdanm | 0:9b334a45a8ff | 10 | * + Initialization and de-initialization functions |
| bogdanm | 0:9b334a45a8ff | 11 | * + IO operation functions |
| bogdanm | 0:9b334a45a8ff | 12 | * + Peripheral Control functions |
| bogdanm | 0:9b334a45a8ff | 13 | * + Peripheral State functions |
| bogdanm | 0:9b334a45a8ff | 14 | * |
| bogdanm | 0:9b334a45a8ff | 15 | @verbatim |
| bogdanm | 0:9b334a45a8ff | 16 | ============================================================================== |
| bogdanm | 0:9b334a45a8ff | 17 | ##### How to use this driver ##### |
| bogdanm | 0:9b334a45a8ff | 18 | ============================================================================== |
| bogdanm | 0:9b334a45a8ff | 19 | [..] |
| bogdanm | 0:9b334a45a8ff | 20 | The PCD HAL driver can be used as follows: |
| bogdanm | 0:9b334a45a8ff | 21 | |
| bogdanm | 0:9b334a45a8ff | 22 | (#) Declare a PCD_HandleTypeDef handle structure, for example: |
| bogdanm | 0:9b334a45a8ff | 23 | PCD_HandleTypeDef hpcd; |
| bogdanm | 0:9b334a45a8ff | 24 | |
| bogdanm | 0:9b334a45a8ff | 25 | (#) Fill parameters of Init structure in HCD handle |
| bogdanm | 0:9b334a45a8ff | 26 | |
| bogdanm | 0:9b334a45a8ff | 27 | (#) Call HAL_PCD_Init() API to initialize the HCD peripheral (Core, Device core, ...) |
| bogdanm | 0:9b334a45a8ff | 28 | |
| bogdanm | 0:9b334a45a8ff | 29 | (#) Initialize the PCD low level resources through the HAL_PCD_MspInit() API: |
| bogdanm | 0:9b334a45a8ff | 30 | (##) Enable the PCD/USB Low Level interface clock using the following macro |
| bogdanm | 0:9b334a45a8ff | 31 | (+++) __HAL_RCC_USB_CLK_ENABLE(); For USB Device FS peripheral available |
| bogdanm | 0:9b334a45a8ff | 32 | on STM32F102xx and STM32F103xx devices |
| bogdanm | 0:9b334a45a8ff | 33 | (+++) __HAL_RCC_USB_OTG_FS_CLK_ENABLE(); For USB OTG FS peripheral available |
| bogdanm | 0:9b334a45a8ff | 34 | on STM32F105xx and STM32F107xx devices |
| bogdanm | 0:9b334a45a8ff | 35 | |
| bogdanm | 0:9b334a45a8ff | 36 | (##) Initialize the related GPIO clocks |
| bogdanm | 0:9b334a45a8ff | 37 | (##) Configure PCD pin-out |
| bogdanm | 0:9b334a45a8ff | 38 | (##) Configure PCD NVIC interrupt |
| bogdanm | 0:9b334a45a8ff | 39 | |
| bogdanm | 0:9b334a45a8ff | 40 | (#)Associate the Upper USB device stack to the HAL PCD Driver: |
| bogdanm | 0:9b334a45a8ff | 41 | (##) hpcd.pData = pdev; |
| bogdanm | 0:9b334a45a8ff | 42 | |
| bogdanm | 0:9b334a45a8ff | 43 | (#)Enable HCD transmission and reception: |
| bogdanm | 0:9b334a45a8ff | 44 | (##) HAL_PCD_Start(); |
| bogdanm | 0:9b334a45a8ff | 45 | |
| bogdanm | 0:9b334a45a8ff | 46 | @endverbatim |
| bogdanm | 0:9b334a45a8ff | 47 | ****************************************************************************** |
| bogdanm | 0:9b334a45a8ff | 48 | * @attention |
| bogdanm | 0:9b334a45a8ff | 49 | * |
| bogdanm | 0:9b334a45a8ff | 50 | * <h2><center>© COPYRIGHT(c) 2014 STMicroelectronics</center></h2> |
| bogdanm | 0:9b334a45a8ff | 51 | * |
| bogdanm | 0:9b334a45a8ff | 52 | * Redistribution and use in source and binary forms, with or without modification, |
| bogdanm | 0:9b334a45a8ff | 53 | * are permitted provided that the following conditions are met: |
| bogdanm | 0:9b334a45a8ff | 54 | * 1. Redistributions of source code must retain the above copyright notice, |
| bogdanm | 0:9b334a45a8ff | 55 | * this list of conditions and the following disclaimer. |
| bogdanm | 0:9b334a45a8ff | 56 | * 2. Redistributions in binary form must reproduce the above copyright notice, |
| bogdanm | 0:9b334a45a8ff | 57 | * this list of conditions and the following disclaimer in the documentation |
| bogdanm | 0:9b334a45a8ff | 58 | * and/or other materials provided with the distribution. |
| bogdanm | 0:9b334a45a8ff | 59 | * 3. Neither the name of STMicroelectronics nor the names of its contributors |
| bogdanm | 0:9b334a45a8ff | 60 | * may be used to endorse or promote products derived from this software |
| bogdanm | 0:9b334a45a8ff | 61 | * without specific prior written permission. |
| bogdanm | 0:9b334a45a8ff | 62 | * |
| bogdanm | 0:9b334a45a8ff | 63 | * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" |
| bogdanm | 0:9b334a45a8ff | 64 | * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
| bogdanm | 0:9b334a45a8ff | 65 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE |
| bogdanm | 0:9b334a45a8ff | 66 | * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE |
| bogdanm | 0:9b334a45a8ff | 67 | * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL |
| bogdanm | 0:9b334a45a8ff | 68 | * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR |
| bogdanm | 0:9b334a45a8ff | 69 | * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER |
| bogdanm | 0:9b334a45a8ff | 70 | * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, |
| bogdanm | 0:9b334a45a8ff | 71 | * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| bogdanm | 0:9b334a45a8ff | 72 | * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| bogdanm | 0:9b334a45a8ff | 73 | * |
| bogdanm | 0:9b334a45a8ff | 74 | ****************************************************************************** |
| bogdanm | 0:9b334a45a8ff | 75 | */ |
| bogdanm | 0:9b334a45a8ff | 76 | |
| bogdanm | 0:9b334a45a8ff | 77 | /* Includes ------------------------------------------------------------------*/ |
| bogdanm | 0:9b334a45a8ff | 78 | #include "stm32f1xx_hal.h" |
| bogdanm | 0:9b334a45a8ff | 79 | |
| bogdanm | 0:9b334a45a8ff | 80 | /** @addtogroup STM32F1xx_HAL_Driver |
| bogdanm | 0:9b334a45a8ff | 81 | * @{ |
| bogdanm | 0:9b334a45a8ff | 82 | */ |
| bogdanm | 0:9b334a45a8ff | 83 | |
| bogdanm | 0:9b334a45a8ff | 84 | |
| bogdanm | 0:9b334a45a8ff | 85 | |
| bogdanm | 0:9b334a45a8ff | 86 | #ifdef HAL_PCD_MODULE_ENABLED |
| bogdanm | 0:9b334a45a8ff | 87 | |
| bogdanm | 0:9b334a45a8ff | 88 | #if defined(STM32F102x6) || defined(STM32F102xB) || \ |
| bogdanm | 0:9b334a45a8ff | 89 | defined(STM32F103x6) || defined(STM32F103xB) || \ |
| bogdanm | 0:9b334a45a8ff | 90 | defined(STM32F103xE) || defined(STM32F103xG) || \ |
| bogdanm | 0:9b334a45a8ff | 91 | defined(STM32F105xC) || defined(STM32F107xC) |
| bogdanm | 0:9b334a45a8ff | 92 | |
| bogdanm | 0:9b334a45a8ff | 93 | /** @defgroup PCD PCD |
| bogdanm | 0:9b334a45a8ff | 94 | * @brief PCD HAL module driver |
| bogdanm | 0:9b334a45a8ff | 95 | * @{ |
| bogdanm | 0:9b334a45a8ff | 96 | */ |
| bogdanm | 0:9b334a45a8ff | 97 | |
| bogdanm | 0:9b334a45a8ff | 98 | /* Private types -------------------------------------------------------------*/ |
| bogdanm | 0:9b334a45a8ff | 99 | /* Private variables ---------------------------------------------------------*/ |
| bogdanm | 0:9b334a45a8ff | 100 | /* Private constants ---------------------------------------------------------*/ |
| bogdanm | 0:9b334a45a8ff | 101 | /* Private macros ------------------------------------------------------------*/ |
| bogdanm | 0:9b334a45a8ff | 102 | /** @defgroup PCD_Private_Macros PCD Private Macros |
| bogdanm | 0:9b334a45a8ff | 103 | * @{ |
| bogdanm | 0:9b334a45a8ff | 104 | */ |
| bogdanm | 0:9b334a45a8ff | 105 | #define PCD_MIN(a, b) (((a) < (b)) ? (a) : (b)) |
| bogdanm | 0:9b334a45a8ff | 106 | #define PCD_MAX(a, b) (((a) > (b)) ? (a) : (b)) |
| bogdanm | 0:9b334a45a8ff | 107 | /** |
| bogdanm | 0:9b334a45a8ff | 108 | * @} |
| bogdanm | 0:9b334a45a8ff | 109 | */ |
| bogdanm | 0:9b334a45a8ff | 110 | |
| bogdanm | 0:9b334a45a8ff | 111 | /* Private functions ---------------------------------------------------------*/ |
| bogdanm | 0:9b334a45a8ff | 112 | /** @defgroup PCD_Private_Functions PCD Private Functions |
| bogdanm | 0:9b334a45a8ff | 113 | * @{ |
| bogdanm | 0:9b334a45a8ff | 114 | */ |
| bogdanm | 0:9b334a45a8ff | 115 | #if defined (USB_OTG_FS) |
| bogdanm | 0:9b334a45a8ff | 116 | static HAL_StatusTypeDef PCD_WriteEmptyTxFifo(PCD_HandleTypeDef *hpcd, uint32_t epnum); |
| bogdanm | 0:9b334a45a8ff | 117 | #endif /* USB_OTG_FS */ |
| bogdanm | 0:9b334a45a8ff | 118 | |
| bogdanm | 0:9b334a45a8ff | 119 | #if defined (USB) |
| bogdanm | 0:9b334a45a8ff | 120 | static HAL_StatusTypeDef PCD_EP_ISR_Handler(PCD_HandleTypeDef *hpcd); |
| bogdanm | 0:9b334a45a8ff | 121 | #endif /* USB */ |
| bogdanm | 0:9b334a45a8ff | 122 | /** |
| bogdanm | 0:9b334a45a8ff | 123 | * @} |
| bogdanm | 0:9b334a45a8ff | 124 | */ |
| bogdanm | 0:9b334a45a8ff | 125 | |
| bogdanm | 0:9b334a45a8ff | 126 | /* Exported functions --------------------------------------------------------*/ |
| bogdanm | 0:9b334a45a8ff | 127 | /** @defgroup PCD_Exported_Functions PCD Exported Functions |
| bogdanm | 0:9b334a45a8ff | 128 | * @{ |
| bogdanm | 0:9b334a45a8ff | 129 | */ |
| bogdanm | 0:9b334a45a8ff | 130 | |
| bogdanm | 0:9b334a45a8ff | 131 | /** @defgroup PCD_Exported_Functions_Group1 Initialization and de-initialization functions |
| bogdanm | 0:9b334a45a8ff | 132 | * @brief Initialization and Configuration functions |
| bogdanm | 0:9b334a45a8ff | 133 | * |
| bogdanm | 0:9b334a45a8ff | 134 | @verbatim |
| bogdanm | 0:9b334a45a8ff | 135 | =============================================================================== |
| bogdanm | 0:9b334a45a8ff | 136 | ##### Initialization and de-initialization functions ##### |
| bogdanm | 0:9b334a45a8ff | 137 | =============================================================================== |
| bogdanm | 0:9b334a45a8ff | 138 | [..] This section provides functions allowing to: |
| bogdanm | 0:9b334a45a8ff | 139 | |
| bogdanm | 0:9b334a45a8ff | 140 | @endverbatim |
| bogdanm | 0:9b334a45a8ff | 141 | * @{ |
| bogdanm | 0:9b334a45a8ff | 142 | */ |
| bogdanm | 0:9b334a45a8ff | 143 | |
| bogdanm | 0:9b334a45a8ff | 144 | /** |
| bogdanm | 0:9b334a45a8ff | 145 | * @brief Initializes the PCD according to the specified |
| bogdanm | 0:9b334a45a8ff | 146 | * parameters in the PCD_InitTypeDef and create the associated handle. |
| bogdanm | 0:9b334a45a8ff | 147 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 148 | * @retval HAL status |
| bogdanm | 0:9b334a45a8ff | 149 | */ |
| bogdanm | 0:9b334a45a8ff | 150 | HAL_StatusTypeDef HAL_PCD_Init(PCD_HandleTypeDef *hpcd) |
| bogdanm | 0:9b334a45a8ff | 151 | { |
| bogdanm | 0:9b334a45a8ff | 152 | uint32_t index = 0; |
| bogdanm | 0:9b334a45a8ff | 153 | |
| bogdanm | 0:9b334a45a8ff | 154 | /* Check the PCD handle allocation */ |
| bogdanm | 0:9b334a45a8ff | 155 | if(hpcd == NULL) |
| bogdanm | 0:9b334a45a8ff | 156 | { |
| bogdanm | 0:9b334a45a8ff | 157 | return HAL_ERROR; |
| bogdanm | 0:9b334a45a8ff | 158 | } |
| bogdanm | 0:9b334a45a8ff | 159 | |
| bogdanm | 0:9b334a45a8ff | 160 | /* Check the parameters */ |
| bogdanm | 0:9b334a45a8ff | 161 | assert_param(IS_PCD_ALL_INSTANCE(hpcd->Instance)); |
| bogdanm | 0:9b334a45a8ff | 162 | |
| bogdanm | 0:9b334a45a8ff | 163 | if(hpcd->State == HAL_PCD_STATE_RESET) |
| bogdanm | 0:9b334a45a8ff | 164 | { |
| bogdanm | 0:9b334a45a8ff | 165 | /* Allocate lock resource and initialize it */ |
| bogdanm | 0:9b334a45a8ff | 166 | hpcd-> Lock = HAL_UNLOCKED; |
| bogdanm | 0:9b334a45a8ff | 167 | |
| bogdanm | 0:9b334a45a8ff | 168 | /* Init the low level hardware : GPIO, CLOCK, NVIC... */ |
| bogdanm | 0:9b334a45a8ff | 169 | HAL_PCD_MspInit(hpcd); |
| bogdanm | 0:9b334a45a8ff | 170 | } |
| bogdanm | 0:9b334a45a8ff | 171 | |
| bogdanm | 0:9b334a45a8ff | 172 | hpcd->State = HAL_PCD_STATE_BUSY; |
| bogdanm | 0:9b334a45a8ff | 173 | |
| bogdanm | 0:9b334a45a8ff | 174 | /* Disable the Interrupts */ |
| bogdanm | 0:9b334a45a8ff | 175 | __HAL_PCD_DISABLE(hpcd); |
| bogdanm | 0:9b334a45a8ff | 176 | |
| bogdanm | 0:9b334a45a8ff | 177 | /*Init the Core (common init.) */ |
| bogdanm | 0:9b334a45a8ff | 178 | USB_CoreInit(hpcd->Instance, hpcd->Init); |
| bogdanm | 0:9b334a45a8ff | 179 | |
| bogdanm | 0:9b334a45a8ff | 180 | /* Force Device Mode*/ |
| bogdanm | 0:9b334a45a8ff | 181 | USB_SetCurrentMode(hpcd->Instance , USB_DEVICE_MODE); |
| bogdanm | 0:9b334a45a8ff | 182 | |
| bogdanm | 0:9b334a45a8ff | 183 | /* Init endpoints structures */ |
| bogdanm | 0:9b334a45a8ff | 184 | for (index = 0; index < 15 ; index++) |
| bogdanm | 0:9b334a45a8ff | 185 | { |
| bogdanm | 0:9b334a45a8ff | 186 | /* Init ep structure */ |
| bogdanm | 0:9b334a45a8ff | 187 | hpcd->IN_ep[index].is_in = 1; |
| bogdanm | 0:9b334a45a8ff | 188 | hpcd->IN_ep[index].num = index; |
| bogdanm | 0:9b334a45a8ff | 189 | hpcd->IN_ep[index].tx_fifo_num = index; |
| bogdanm | 0:9b334a45a8ff | 190 | /* Control until ep is actvated */ |
| bogdanm | 0:9b334a45a8ff | 191 | hpcd->IN_ep[index].type = EP_TYPE_CTRL; |
| bogdanm | 0:9b334a45a8ff | 192 | hpcd->IN_ep[index].maxpacket = 0; |
| bogdanm | 0:9b334a45a8ff | 193 | hpcd->IN_ep[index].xfer_buff = 0; |
| bogdanm | 0:9b334a45a8ff | 194 | hpcd->IN_ep[index].xfer_len = 0; |
| bogdanm | 0:9b334a45a8ff | 195 | } |
| bogdanm | 0:9b334a45a8ff | 196 | |
| bogdanm | 0:9b334a45a8ff | 197 | for (index = 0; index < 15 ; index++) |
| bogdanm | 0:9b334a45a8ff | 198 | { |
| bogdanm | 0:9b334a45a8ff | 199 | hpcd->OUT_ep[index].is_in = 0; |
| bogdanm | 0:9b334a45a8ff | 200 | hpcd->OUT_ep[index].num = index; |
| bogdanm | 0:9b334a45a8ff | 201 | hpcd->IN_ep[index].tx_fifo_num = index; |
| bogdanm | 0:9b334a45a8ff | 202 | /* Control until ep is activated */ |
| bogdanm | 0:9b334a45a8ff | 203 | hpcd->OUT_ep[index].type = EP_TYPE_CTRL; |
| bogdanm | 0:9b334a45a8ff | 204 | hpcd->OUT_ep[index].maxpacket = 0; |
| bogdanm | 0:9b334a45a8ff | 205 | hpcd->OUT_ep[index].xfer_buff = 0; |
| bogdanm | 0:9b334a45a8ff | 206 | hpcd->OUT_ep[index].xfer_len = 0; |
| bogdanm | 0:9b334a45a8ff | 207 | } |
| bogdanm | 0:9b334a45a8ff | 208 | |
| bogdanm | 0:9b334a45a8ff | 209 | /* Init Device */ |
| bogdanm | 0:9b334a45a8ff | 210 | USB_DevInit(hpcd->Instance, hpcd->Init); |
| bogdanm | 0:9b334a45a8ff | 211 | |
| bogdanm | 0:9b334a45a8ff | 212 | hpcd->USB_Address = 0; |
| bogdanm | 0:9b334a45a8ff | 213 | hpcd->State= HAL_PCD_STATE_READY; |
| bogdanm | 0:9b334a45a8ff | 214 | |
| bogdanm | 0:9b334a45a8ff | 215 | USB_DevDisconnect (hpcd->Instance); |
| bogdanm | 0:9b334a45a8ff | 216 | return HAL_OK; |
| bogdanm | 0:9b334a45a8ff | 217 | } |
| bogdanm | 0:9b334a45a8ff | 218 | |
| bogdanm | 0:9b334a45a8ff | 219 | /** |
| bogdanm | 0:9b334a45a8ff | 220 | * @brief DeInitializes the PCD peripheral |
| bogdanm | 0:9b334a45a8ff | 221 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 222 | * @retval HAL status |
| bogdanm | 0:9b334a45a8ff | 223 | */ |
| bogdanm | 0:9b334a45a8ff | 224 | HAL_StatusTypeDef HAL_PCD_DeInit(PCD_HandleTypeDef *hpcd) |
| bogdanm | 0:9b334a45a8ff | 225 | { |
| bogdanm | 0:9b334a45a8ff | 226 | /* Check the PCD handle allocation */ |
| bogdanm | 0:9b334a45a8ff | 227 | if(hpcd == NULL) |
| bogdanm | 0:9b334a45a8ff | 228 | { |
| bogdanm | 0:9b334a45a8ff | 229 | return HAL_ERROR; |
| bogdanm | 0:9b334a45a8ff | 230 | } |
| bogdanm | 0:9b334a45a8ff | 231 | |
| bogdanm | 0:9b334a45a8ff | 232 | hpcd->State = HAL_PCD_STATE_BUSY; |
| bogdanm | 0:9b334a45a8ff | 233 | |
| bogdanm | 0:9b334a45a8ff | 234 | /* Stop Device */ |
| bogdanm | 0:9b334a45a8ff | 235 | HAL_PCD_Stop(hpcd); |
| bogdanm | 0:9b334a45a8ff | 236 | |
| bogdanm | 0:9b334a45a8ff | 237 | /* DeInit the low level hardware */ |
| bogdanm | 0:9b334a45a8ff | 238 | HAL_PCD_MspDeInit(hpcd); |
| bogdanm | 0:9b334a45a8ff | 239 | |
| bogdanm | 0:9b334a45a8ff | 240 | hpcd->State = HAL_PCD_STATE_RESET; |
| bogdanm | 0:9b334a45a8ff | 241 | |
| bogdanm | 0:9b334a45a8ff | 242 | return HAL_OK; |
| bogdanm | 0:9b334a45a8ff | 243 | } |
| bogdanm | 0:9b334a45a8ff | 244 | |
| bogdanm | 0:9b334a45a8ff | 245 | /** |
| bogdanm | 0:9b334a45a8ff | 246 | * @brief Initializes the PCD MSP. |
| bogdanm | 0:9b334a45a8ff | 247 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 248 | * @retval None |
| bogdanm | 0:9b334a45a8ff | 249 | */ |
| bogdanm | 0:9b334a45a8ff | 250 | __weak void HAL_PCD_MspInit(PCD_HandleTypeDef *hpcd) |
| bogdanm | 0:9b334a45a8ff | 251 | { |
| bogdanm | 0:9b334a45a8ff | 252 | /* NOTE : This function should not be modified, when the callback is needed, |
| bogdanm | 0:9b334a45a8ff | 253 | the HAL_PCD_MspInit could be implemented in the user file |
| bogdanm | 0:9b334a45a8ff | 254 | */ |
| bogdanm | 0:9b334a45a8ff | 255 | } |
| bogdanm | 0:9b334a45a8ff | 256 | |
| bogdanm | 0:9b334a45a8ff | 257 | /** |
| bogdanm | 0:9b334a45a8ff | 258 | * @brief DeInitializes PCD MSP. |
| bogdanm | 0:9b334a45a8ff | 259 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 260 | * @retval None |
| bogdanm | 0:9b334a45a8ff | 261 | */ |
| bogdanm | 0:9b334a45a8ff | 262 | __weak void HAL_PCD_MspDeInit(PCD_HandleTypeDef *hpcd) |
| bogdanm | 0:9b334a45a8ff | 263 | { |
| bogdanm | 0:9b334a45a8ff | 264 | /* NOTE : This function should not be modified, when the callback is needed, |
| bogdanm | 0:9b334a45a8ff | 265 | the HAL_PCD_MspDeInit could be implemented in the user file |
| bogdanm | 0:9b334a45a8ff | 266 | */ |
| bogdanm | 0:9b334a45a8ff | 267 | } |
| bogdanm | 0:9b334a45a8ff | 268 | |
| bogdanm | 0:9b334a45a8ff | 269 | /** |
| bogdanm | 0:9b334a45a8ff | 270 | * @} |
| bogdanm | 0:9b334a45a8ff | 271 | */ |
| bogdanm | 0:9b334a45a8ff | 272 | |
| bogdanm | 0:9b334a45a8ff | 273 | /** @defgroup PCD_Exported_Functions_Group2 IO operation functions |
| bogdanm | 0:9b334a45a8ff | 274 | * @brief Data transfers functions |
| bogdanm | 0:9b334a45a8ff | 275 | * |
| bogdanm | 0:9b334a45a8ff | 276 | @verbatim |
| bogdanm | 0:9b334a45a8ff | 277 | =============================================================================== |
| bogdanm | 0:9b334a45a8ff | 278 | ##### IO operation functions ##### |
| bogdanm | 0:9b334a45a8ff | 279 | =============================================================================== |
| bogdanm | 0:9b334a45a8ff | 280 | [..] |
| bogdanm | 0:9b334a45a8ff | 281 | This subsection provides a set of functions allowing to manage the PCD data |
| bogdanm | 0:9b334a45a8ff | 282 | transfers. |
| bogdanm | 0:9b334a45a8ff | 283 | |
| bogdanm | 0:9b334a45a8ff | 284 | @endverbatim |
| bogdanm | 0:9b334a45a8ff | 285 | * @{ |
| bogdanm | 0:9b334a45a8ff | 286 | */ |
| bogdanm | 0:9b334a45a8ff | 287 | |
| bogdanm | 0:9b334a45a8ff | 288 | /** |
| bogdanm | 0:9b334a45a8ff | 289 | * @brief Start The USB Device. |
| bogdanm | 0:9b334a45a8ff | 290 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 291 | * @retval HAL status |
| bogdanm | 0:9b334a45a8ff | 292 | */ |
| bogdanm | 0:9b334a45a8ff | 293 | HAL_StatusTypeDef HAL_PCD_Start(PCD_HandleTypeDef *hpcd) |
| bogdanm | 0:9b334a45a8ff | 294 | { |
| bogdanm | 0:9b334a45a8ff | 295 | __HAL_LOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 296 | HAL_PCDEx_SetConnectionState (hpcd, 1); |
| bogdanm | 0:9b334a45a8ff | 297 | USB_DevConnect (hpcd->Instance); |
| bogdanm | 0:9b334a45a8ff | 298 | __HAL_PCD_ENABLE(hpcd); |
| bogdanm | 0:9b334a45a8ff | 299 | __HAL_UNLOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 300 | return HAL_OK; |
| bogdanm | 0:9b334a45a8ff | 301 | } |
| bogdanm | 0:9b334a45a8ff | 302 | |
| bogdanm | 0:9b334a45a8ff | 303 | /** |
| bogdanm | 0:9b334a45a8ff | 304 | * @brief Stop The USB Device. |
| bogdanm | 0:9b334a45a8ff | 305 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 306 | * @retval HAL status |
| bogdanm | 0:9b334a45a8ff | 307 | */ |
| bogdanm | 0:9b334a45a8ff | 308 | HAL_StatusTypeDef HAL_PCD_Stop(PCD_HandleTypeDef *hpcd) |
| bogdanm | 0:9b334a45a8ff | 309 | { |
| bogdanm | 0:9b334a45a8ff | 310 | __HAL_LOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 311 | __HAL_PCD_DISABLE(hpcd); |
| bogdanm | 0:9b334a45a8ff | 312 | USB_StopDevice(hpcd->Instance); |
| bogdanm | 0:9b334a45a8ff | 313 | USB_DevDisconnect (hpcd->Instance); |
| bogdanm | 0:9b334a45a8ff | 314 | __HAL_UNLOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 315 | return HAL_OK; |
| bogdanm | 0:9b334a45a8ff | 316 | } |
| bogdanm | 0:9b334a45a8ff | 317 | |
| bogdanm | 0:9b334a45a8ff | 318 | #if defined (USB_OTG_FS) |
| bogdanm | 0:9b334a45a8ff | 319 | /** |
| bogdanm | 0:9b334a45a8ff | 320 | * @brief This function handles PCD interrupt request. |
| bogdanm | 0:9b334a45a8ff | 321 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 322 | * @retval HAL status |
| bogdanm | 0:9b334a45a8ff | 323 | */ |
| bogdanm | 0:9b334a45a8ff | 324 | void HAL_PCD_IRQHandler(PCD_HandleTypeDef *hpcd) |
| bogdanm | 0:9b334a45a8ff | 325 | { |
| bogdanm | 0:9b334a45a8ff | 326 | USB_OTG_GlobalTypeDef *USBx = hpcd->Instance; |
| bogdanm | 0:9b334a45a8ff | 327 | uint32_t index = 0, ep_intr = 0, epint = 0, epnum = 0; |
| bogdanm | 0:9b334a45a8ff | 328 | uint32_t fifoemptymsk = 0, temp = 0; |
| bogdanm | 0:9b334a45a8ff | 329 | USB_OTG_EPTypeDef *ep = NULL; |
| bogdanm | 0:9b334a45a8ff | 330 | |
| bogdanm | 0:9b334a45a8ff | 331 | /* ensure that we are in device mode */ |
| bogdanm | 0:9b334a45a8ff | 332 | if (USB_GetMode(hpcd->Instance) == USB_OTG_MODE_DEVICE) |
| bogdanm | 0:9b334a45a8ff | 333 | { |
| bogdanm | 0:9b334a45a8ff | 334 | /* avoid spurious interrupt */ |
| bogdanm | 0:9b334a45a8ff | 335 | if(__HAL_PCD_IS_INVALID_INTERRUPT(hpcd)) |
| bogdanm | 0:9b334a45a8ff | 336 | { |
| bogdanm | 0:9b334a45a8ff | 337 | return; |
| bogdanm | 0:9b334a45a8ff | 338 | } |
| bogdanm | 0:9b334a45a8ff | 339 | |
| bogdanm | 0:9b334a45a8ff | 340 | if(__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_MMIS)) |
| bogdanm | 0:9b334a45a8ff | 341 | { |
| bogdanm | 0:9b334a45a8ff | 342 | /* incorrect mode, acknowledge the interrupt */ |
| bogdanm | 0:9b334a45a8ff | 343 | __HAL_PCD_CLEAR_FLAG(hpcd, USB_OTG_GINTSTS_MMIS); |
| bogdanm | 0:9b334a45a8ff | 344 | } |
| bogdanm | 0:9b334a45a8ff | 345 | |
| bogdanm | 0:9b334a45a8ff | 346 | if(__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_OEPINT)) |
| bogdanm | 0:9b334a45a8ff | 347 | { |
| bogdanm | 0:9b334a45a8ff | 348 | epnum = 0; |
| bogdanm | 0:9b334a45a8ff | 349 | |
| bogdanm | 0:9b334a45a8ff | 350 | /* Read in the device interrupt bits */ |
| bogdanm | 0:9b334a45a8ff | 351 | ep_intr = USB_ReadDevAllOutEpInterrupt(hpcd->Instance); |
| bogdanm | 0:9b334a45a8ff | 352 | |
| bogdanm | 0:9b334a45a8ff | 353 | while ( ep_intr ) |
| bogdanm | 0:9b334a45a8ff | 354 | { |
| bogdanm | 0:9b334a45a8ff | 355 | if (ep_intr & 0x1) |
| bogdanm | 0:9b334a45a8ff | 356 | { |
| bogdanm | 0:9b334a45a8ff | 357 | epint = USB_ReadDevOutEPInterrupt(hpcd->Instance, epnum); |
| bogdanm | 0:9b334a45a8ff | 358 | |
| bogdanm | 0:9b334a45a8ff | 359 | if(( epint & USB_OTG_DOEPINT_XFRC) == USB_OTG_DOEPINT_XFRC) |
| bogdanm | 0:9b334a45a8ff | 360 | { |
| bogdanm | 0:9b334a45a8ff | 361 | CLEAR_OUT_EP_INTR(epnum, USB_OTG_DOEPINT_XFRC); |
| bogdanm | 0:9b334a45a8ff | 362 | |
| bogdanm | 0:9b334a45a8ff | 363 | HAL_PCD_DataOutStageCallback(hpcd, epnum); |
| bogdanm | 0:9b334a45a8ff | 364 | } |
| bogdanm | 0:9b334a45a8ff | 365 | |
| bogdanm | 0:9b334a45a8ff | 366 | if(( epint & USB_OTG_DOEPINT_STUP) == USB_OTG_DOEPINT_STUP) |
| bogdanm | 0:9b334a45a8ff | 367 | { |
| bogdanm | 0:9b334a45a8ff | 368 | /* Inform the upper layer that a setup packet is available */ |
| bogdanm | 0:9b334a45a8ff | 369 | HAL_PCD_SetupStageCallback(hpcd); |
| bogdanm | 0:9b334a45a8ff | 370 | CLEAR_OUT_EP_INTR(epnum, USB_OTG_DOEPINT_STUP); |
| bogdanm | 0:9b334a45a8ff | 371 | } |
| bogdanm | 0:9b334a45a8ff | 372 | |
| bogdanm | 0:9b334a45a8ff | 373 | if(( epint & USB_OTG_DOEPINT_OTEPDIS) == USB_OTG_DOEPINT_OTEPDIS) |
| bogdanm | 0:9b334a45a8ff | 374 | { |
| bogdanm | 0:9b334a45a8ff | 375 | CLEAR_OUT_EP_INTR(epnum, USB_OTG_DOEPINT_OTEPDIS); |
| bogdanm | 0:9b334a45a8ff | 376 | } |
| bogdanm | 0:9b334a45a8ff | 377 | } |
| bogdanm | 0:9b334a45a8ff | 378 | epnum++; |
| bogdanm | 0:9b334a45a8ff | 379 | ep_intr >>= 1; |
| bogdanm | 0:9b334a45a8ff | 380 | } |
| bogdanm | 0:9b334a45a8ff | 381 | } |
| bogdanm | 0:9b334a45a8ff | 382 | |
| bogdanm | 0:9b334a45a8ff | 383 | if(__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_IEPINT)) |
| bogdanm | 0:9b334a45a8ff | 384 | { |
| bogdanm | 0:9b334a45a8ff | 385 | /* Read in the device interrupt bits */ |
| bogdanm | 0:9b334a45a8ff | 386 | ep_intr = USB_ReadDevAllInEpInterrupt(hpcd->Instance); |
| bogdanm | 0:9b334a45a8ff | 387 | |
| bogdanm | 0:9b334a45a8ff | 388 | epnum = 0; |
| bogdanm | 0:9b334a45a8ff | 389 | |
| bogdanm | 0:9b334a45a8ff | 390 | while ( ep_intr ) |
| bogdanm | 0:9b334a45a8ff | 391 | { |
| bogdanm | 0:9b334a45a8ff | 392 | if (ep_intr & 0x1) /* In ITR */ |
| bogdanm | 0:9b334a45a8ff | 393 | { |
| bogdanm | 0:9b334a45a8ff | 394 | epint = USB_ReadDevInEPInterrupt(hpcd->Instance, epnum); |
| bogdanm | 0:9b334a45a8ff | 395 | |
| bogdanm | 0:9b334a45a8ff | 396 | if(( epint & USB_OTG_DIEPINT_XFRC) == USB_OTG_DIEPINT_XFRC) |
| bogdanm | 0:9b334a45a8ff | 397 | { |
| bogdanm | 0:9b334a45a8ff | 398 | fifoemptymsk = 0x1 << epnum; |
| bogdanm | 0:9b334a45a8ff | 399 | USBx_DEVICE->DIEPEMPMSK &= ~fifoemptymsk; |
| bogdanm | 0:9b334a45a8ff | 400 | |
| bogdanm | 0:9b334a45a8ff | 401 | CLEAR_IN_EP_INTR(epnum, USB_OTG_DIEPINT_XFRC); |
| bogdanm | 0:9b334a45a8ff | 402 | |
| bogdanm | 0:9b334a45a8ff | 403 | HAL_PCD_DataInStageCallback(hpcd, epnum); |
| bogdanm | 0:9b334a45a8ff | 404 | } |
| bogdanm | 0:9b334a45a8ff | 405 | if(( epint & USB_OTG_DIEPINT_TOC) == USB_OTG_DIEPINT_TOC) |
| bogdanm | 0:9b334a45a8ff | 406 | { |
| bogdanm | 0:9b334a45a8ff | 407 | CLEAR_IN_EP_INTR(epnum, USB_OTG_DIEPINT_TOC); |
| bogdanm | 0:9b334a45a8ff | 408 | } |
| bogdanm | 0:9b334a45a8ff | 409 | if(( epint & USB_OTG_DIEPINT_ITTXFE) == USB_OTG_DIEPINT_ITTXFE) |
| bogdanm | 0:9b334a45a8ff | 410 | { |
| bogdanm | 0:9b334a45a8ff | 411 | CLEAR_IN_EP_INTR(epnum, USB_OTG_DIEPINT_ITTXFE); |
| bogdanm | 0:9b334a45a8ff | 412 | } |
| bogdanm | 0:9b334a45a8ff | 413 | if(( epint & USB_OTG_DIEPINT_INEPNE) == USB_OTG_DIEPINT_INEPNE) |
| bogdanm | 0:9b334a45a8ff | 414 | { |
| bogdanm | 0:9b334a45a8ff | 415 | CLEAR_IN_EP_INTR(epnum, USB_OTG_DIEPINT_INEPNE); |
| bogdanm | 0:9b334a45a8ff | 416 | } |
| bogdanm | 0:9b334a45a8ff | 417 | if(( epint & USB_OTG_DIEPINT_EPDISD) == USB_OTG_DIEPINT_EPDISD) |
| bogdanm | 0:9b334a45a8ff | 418 | { |
| bogdanm | 0:9b334a45a8ff | 419 | CLEAR_IN_EP_INTR(epnum, USB_OTG_DIEPINT_EPDISD); |
| bogdanm | 0:9b334a45a8ff | 420 | } |
| bogdanm | 0:9b334a45a8ff | 421 | if(( epint & USB_OTG_DIEPINT_TXFE) == USB_OTG_DIEPINT_TXFE) |
| bogdanm | 0:9b334a45a8ff | 422 | { |
| bogdanm | 0:9b334a45a8ff | 423 | PCD_WriteEmptyTxFifo(hpcd , epnum); |
| bogdanm | 0:9b334a45a8ff | 424 | } |
| bogdanm | 0:9b334a45a8ff | 425 | } |
| bogdanm | 0:9b334a45a8ff | 426 | epnum++; |
| bogdanm | 0:9b334a45a8ff | 427 | ep_intr >>= 1; |
| bogdanm | 0:9b334a45a8ff | 428 | } |
| bogdanm | 0:9b334a45a8ff | 429 | } |
| bogdanm | 0:9b334a45a8ff | 430 | |
| bogdanm | 0:9b334a45a8ff | 431 | /* Handle Resume Interrupt */ |
| bogdanm | 0:9b334a45a8ff | 432 | if(__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_WKUINT)) |
| bogdanm | 0:9b334a45a8ff | 433 | { |
| bogdanm | 0:9b334a45a8ff | 434 | /* Clear the Remote Wake-up signalling */ |
| bogdanm | 0:9b334a45a8ff | 435 | USBx_DEVICE->DCTL &= ~USB_OTG_DCTL_RWUSIG; |
| bogdanm | 0:9b334a45a8ff | 436 | |
| bogdanm | 0:9b334a45a8ff | 437 | HAL_PCD_ResumeCallback(hpcd); |
| bogdanm | 0:9b334a45a8ff | 438 | |
| bogdanm | 0:9b334a45a8ff | 439 | __HAL_PCD_CLEAR_FLAG(hpcd, USB_OTG_GINTSTS_WKUINT); |
| bogdanm | 0:9b334a45a8ff | 440 | } |
| bogdanm | 0:9b334a45a8ff | 441 | |
| bogdanm | 0:9b334a45a8ff | 442 | /* Handle Suspend Interrupt */ |
| bogdanm | 0:9b334a45a8ff | 443 | if(__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_USBSUSP)) |
| bogdanm | 0:9b334a45a8ff | 444 | { |
| bogdanm | 0:9b334a45a8ff | 445 | if((USBx_DEVICE->DSTS & USB_OTG_DSTS_SUSPSTS) == USB_OTG_DSTS_SUSPSTS) |
| bogdanm | 0:9b334a45a8ff | 446 | { |
| bogdanm | 0:9b334a45a8ff | 447 | |
| bogdanm | 0:9b334a45a8ff | 448 | HAL_PCD_SuspendCallback(hpcd); |
| bogdanm | 0:9b334a45a8ff | 449 | } |
| bogdanm | 0:9b334a45a8ff | 450 | __HAL_PCD_CLEAR_FLAG(hpcd, USB_OTG_GINTSTS_USBSUSP); |
| bogdanm | 0:9b334a45a8ff | 451 | } |
| bogdanm | 0:9b334a45a8ff | 452 | |
| bogdanm | 0:9b334a45a8ff | 453 | /* Handle Reset Interrupt */ |
| bogdanm | 0:9b334a45a8ff | 454 | if(__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_USBRST)) |
| bogdanm | 0:9b334a45a8ff | 455 | { |
| bogdanm | 0:9b334a45a8ff | 456 | USBx_DEVICE->DCTL &= ~USB_OTG_DCTL_RWUSIG; |
| bogdanm | 0:9b334a45a8ff | 457 | USB_FlushTxFifo(hpcd->Instance , 0 ); |
| bogdanm | 0:9b334a45a8ff | 458 | |
| bogdanm | 0:9b334a45a8ff | 459 | for (index = 0; index < hpcd->Init.dev_endpoints ; index++) |
| bogdanm | 0:9b334a45a8ff | 460 | { |
| bogdanm | 0:9b334a45a8ff | 461 | USBx_INEP(index)->DIEPINT = 0xFF; |
| bogdanm | 0:9b334a45a8ff | 462 | USBx_OUTEP(index)->DOEPINT = 0xFF; |
| bogdanm | 0:9b334a45a8ff | 463 | } |
| bogdanm | 0:9b334a45a8ff | 464 | USBx_DEVICE->DAINT = 0xFFFFFFFF; |
| bogdanm | 0:9b334a45a8ff | 465 | USBx_DEVICE->DAINTMSK |= 0x10001; |
| bogdanm | 0:9b334a45a8ff | 466 | |
| bogdanm | 0:9b334a45a8ff | 467 | USBx_DEVICE->DOEPMSK |= (USB_OTG_DOEPMSK_STUPM | USB_OTG_DOEPMSK_XFRCM | USB_OTG_DOEPMSK_EPDM); |
| bogdanm | 0:9b334a45a8ff | 468 | USBx_DEVICE->DIEPMSK |= (USB_OTG_DIEPMSK_TOM | USB_OTG_DIEPMSK_XFRCM | USB_OTG_DIEPMSK_EPDM); |
| bogdanm | 0:9b334a45a8ff | 469 | |
| bogdanm | 0:9b334a45a8ff | 470 | /* Set Default Address to 0 */ |
| bogdanm | 0:9b334a45a8ff | 471 | USBx_DEVICE->DCFG &= ~USB_OTG_DCFG_DAD; |
| bogdanm | 0:9b334a45a8ff | 472 | |
| bogdanm | 0:9b334a45a8ff | 473 | /* setup EP0 to receive SETUP packets */ |
| bogdanm | 0:9b334a45a8ff | 474 | USB_EP0_OutStart(hpcd->Instance, (uint8_t *)hpcd->Setup); |
| bogdanm | 0:9b334a45a8ff | 475 | |
| bogdanm | 0:9b334a45a8ff | 476 | __HAL_PCD_CLEAR_FLAG(hpcd, USB_OTG_GINTSTS_USBRST); |
| bogdanm | 0:9b334a45a8ff | 477 | } |
| bogdanm | 0:9b334a45a8ff | 478 | |
| bogdanm | 0:9b334a45a8ff | 479 | /* Handle Enumeration done Interrupt */ |
| bogdanm | 0:9b334a45a8ff | 480 | if(__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_ENUMDNE)) |
| bogdanm | 0:9b334a45a8ff | 481 | { |
| bogdanm | 0:9b334a45a8ff | 482 | USB_ActivateSetup(hpcd->Instance); |
| bogdanm | 0:9b334a45a8ff | 483 | hpcd->Instance->GUSBCFG &= ~USB_OTG_GUSBCFG_TRDT; |
| bogdanm | 0:9b334a45a8ff | 484 | |
| bogdanm | 0:9b334a45a8ff | 485 | hpcd->Init.speed = USB_OTG_SPEED_FULL; |
| bogdanm | 0:9b334a45a8ff | 486 | hpcd->Init.ep0_mps = USB_OTG_FS_MAX_PACKET_SIZE ; |
| bogdanm | 0:9b334a45a8ff | 487 | hpcd->Instance->GUSBCFG |= (USB_OTG_GUSBCFG_TRDT_0 | USB_OTG_GUSBCFG_TRDT_2); |
| bogdanm | 0:9b334a45a8ff | 488 | |
| bogdanm | 0:9b334a45a8ff | 489 | HAL_PCD_ResetCallback(hpcd); |
| bogdanm | 0:9b334a45a8ff | 490 | |
| bogdanm | 0:9b334a45a8ff | 491 | __HAL_PCD_CLEAR_FLAG(hpcd, USB_OTG_GINTSTS_ENUMDNE); |
| bogdanm | 0:9b334a45a8ff | 492 | } |
| bogdanm | 0:9b334a45a8ff | 493 | |
| bogdanm | 0:9b334a45a8ff | 494 | /* Handle RxQLevel Interrupt */ |
| bogdanm | 0:9b334a45a8ff | 495 | if(__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_RXFLVL)) |
| bogdanm | 0:9b334a45a8ff | 496 | { |
| bogdanm | 0:9b334a45a8ff | 497 | USB_MASK_INTERRUPT(hpcd->Instance, USB_OTG_GINTSTS_RXFLVL); |
| bogdanm | 0:9b334a45a8ff | 498 | temp = USBx->GRXSTSP; |
| bogdanm | 0:9b334a45a8ff | 499 | ep = &hpcd->OUT_ep[temp & USB_OTG_GRXSTSP_EPNUM]; |
| bogdanm | 0:9b334a45a8ff | 500 | |
| bogdanm | 0:9b334a45a8ff | 501 | if(((temp & USB_OTG_GRXSTSP_PKTSTS) >> 17) == STS_DATA_UPDT) |
| bogdanm | 0:9b334a45a8ff | 502 | { |
| bogdanm | 0:9b334a45a8ff | 503 | if((temp & USB_OTG_GRXSTSP_BCNT) != 0) |
| bogdanm | 0:9b334a45a8ff | 504 | { |
| bogdanm | 0:9b334a45a8ff | 505 | USB_ReadPacket(USBx, ep->xfer_buff, (temp & USB_OTG_GRXSTSP_BCNT) >> 4); |
| bogdanm | 0:9b334a45a8ff | 506 | ep->xfer_buff += (temp & USB_OTG_GRXSTSP_BCNT) >> 4; |
| bogdanm | 0:9b334a45a8ff | 507 | ep->xfer_count += (temp & USB_OTG_GRXSTSP_BCNT) >> 4; |
| bogdanm | 0:9b334a45a8ff | 508 | } |
| bogdanm | 0:9b334a45a8ff | 509 | } |
| bogdanm | 0:9b334a45a8ff | 510 | else if (((temp & USB_OTG_GRXSTSP_PKTSTS) >> 17) == STS_SETUP_UPDT) |
| bogdanm | 0:9b334a45a8ff | 511 | { |
| bogdanm | 0:9b334a45a8ff | 512 | USB_ReadPacket(USBx, (uint8_t *)hpcd->Setup, 8); |
| bogdanm | 0:9b334a45a8ff | 513 | ep->xfer_count += (temp & USB_OTG_GRXSTSP_BCNT) >> 4; |
| bogdanm | 0:9b334a45a8ff | 514 | } |
| bogdanm | 0:9b334a45a8ff | 515 | USB_UNMASK_INTERRUPT(hpcd->Instance, USB_OTG_GINTSTS_RXFLVL); |
| bogdanm | 0:9b334a45a8ff | 516 | } |
| bogdanm | 0:9b334a45a8ff | 517 | |
| bogdanm | 0:9b334a45a8ff | 518 | /* Handle SOF Interrupt */ |
| bogdanm | 0:9b334a45a8ff | 519 | if(__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_SOF)) |
| bogdanm | 0:9b334a45a8ff | 520 | { |
| bogdanm | 0:9b334a45a8ff | 521 | HAL_PCD_SOFCallback(hpcd); |
| bogdanm | 0:9b334a45a8ff | 522 | __HAL_PCD_CLEAR_FLAG(hpcd, USB_OTG_GINTSTS_SOF); |
| bogdanm | 0:9b334a45a8ff | 523 | } |
| bogdanm | 0:9b334a45a8ff | 524 | |
| bogdanm | 0:9b334a45a8ff | 525 | /* Handle Incomplete ISO IN Interrupt */ |
| bogdanm | 0:9b334a45a8ff | 526 | if(__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_IISOIXFR)) |
| bogdanm | 0:9b334a45a8ff | 527 | { |
| bogdanm | 0:9b334a45a8ff | 528 | HAL_PCD_ISOINIncompleteCallback(hpcd, epnum); |
| bogdanm | 0:9b334a45a8ff | 529 | __HAL_PCD_CLEAR_FLAG(hpcd, USB_OTG_GINTSTS_IISOIXFR); |
| bogdanm | 0:9b334a45a8ff | 530 | } |
| bogdanm | 0:9b334a45a8ff | 531 | |
| bogdanm | 0:9b334a45a8ff | 532 | /* Handle Incomplete ISO OUT Interrupt */ |
| bogdanm | 0:9b334a45a8ff | 533 | if(__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_PXFR_INCOMPISOOUT)) |
| bogdanm | 0:9b334a45a8ff | 534 | { |
| bogdanm | 0:9b334a45a8ff | 535 | HAL_PCD_ISOOUTIncompleteCallback(hpcd, epnum); |
| bogdanm | 0:9b334a45a8ff | 536 | __HAL_PCD_CLEAR_FLAG(hpcd, USB_OTG_GINTSTS_PXFR_INCOMPISOOUT); |
| bogdanm | 0:9b334a45a8ff | 537 | } |
| bogdanm | 0:9b334a45a8ff | 538 | |
| bogdanm | 0:9b334a45a8ff | 539 | /* Handle Connection event Interrupt */ |
| bogdanm | 0:9b334a45a8ff | 540 | if(__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_SRQINT)) |
| bogdanm | 0:9b334a45a8ff | 541 | { |
| bogdanm | 0:9b334a45a8ff | 542 | HAL_PCD_ConnectCallback(hpcd); |
| bogdanm | 0:9b334a45a8ff | 543 | __HAL_PCD_CLEAR_FLAG(hpcd, USB_OTG_GINTSTS_SRQINT); |
| bogdanm | 0:9b334a45a8ff | 544 | } |
| bogdanm | 0:9b334a45a8ff | 545 | |
| bogdanm | 0:9b334a45a8ff | 546 | /* Handle Disconnection event Interrupt */ |
| bogdanm | 0:9b334a45a8ff | 547 | if(__HAL_PCD_GET_FLAG(hpcd, USB_OTG_GINTSTS_OTGINT)) |
| bogdanm | 0:9b334a45a8ff | 548 | { |
| bogdanm | 0:9b334a45a8ff | 549 | temp = hpcd->Instance->GOTGINT; |
| bogdanm | 0:9b334a45a8ff | 550 | |
| bogdanm | 0:9b334a45a8ff | 551 | if((temp & USB_OTG_GOTGINT_SEDET) == USB_OTG_GOTGINT_SEDET) |
| bogdanm | 0:9b334a45a8ff | 552 | { |
| bogdanm | 0:9b334a45a8ff | 553 | HAL_PCD_DisconnectCallback(hpcd); |
| bogdanm | 0:9b334a45a8ff | 554 | } |
| bogdanm | 0:9b334a45a8ff | 555 | hpcd->Instance->GOTGINT |= temp; |
| bogdanm | 0:9b334a45a8ff | 556 | } |
| bogdanm | 0:9b334a45a8ff | 557 | } |
| bogdanm | 0:9b334a45a8ff | 558 | } |
| bogdanm | 0:9b334a45a8ff | 559 | #endif /* USB_OTG_FS */ |
| bogdanm | 0:9b334a45a8ff | 560 | |
| bogdanm | 0:9b334a45a8ff | 561 | #if defined (USB) |
| bogdanm | 0:9b334a45a8ff | 562 | /** |
| bogdanm | 0:9b334a45a8ff | 563 | * @brief This function handles PCD interrupt request. |
| bogdanm | 0:9b334a45a8ff | 564 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 565 | * @retval HAL status |
| bogdanm | 0:9b334a45a8ff | 566 | */ |
| bogdanm | 0:9b334a45a8ff | 567 | void HAL_PCD_IRQHandler(PCD_HandleTypeDef *hpcd) |
| bogdanm | 0:9b334a45a8ff | 568 | { |
| bogdanm | 0:9b334a45a8ff | 569 | uint32_t wInterrupt_Mask = 0; |
| bogdanm | 0:9b334a45a8ff | 570 | |
| bogdanm | 0:9b334a45a8ff | 571 | if (__HAL_PCD_GET_FLAG (hpcd, USB_ISTR_CTR)) |
| bogdanm | 0:9b334a45a8ff | 572 | { |
| bogdanm | 0:9b334a45a8ff | 573 | /* servicing of the endpoint correct transfer interrupt */ |
| bogdanm | 0:9b334a45a8ff | 574 | /* clear of the CTR flag into the sub */ |
| bogdanm | 0:9b334a45a8ff | 575 | PCD_EP_ISR_Handler(hpcd); |
| bogdanm | 0:9b334a45a8ff | 576 | } |
| bogdanm | 0:9b334a45a8ff | 577 | |
| bogdanm | 0:9b334a45a8ff | 578 | if (__HAL_PCD_GET_FLAG (hpcd, USB_ISTR_RESET)) |
| bogdanm | 0:9b334a45a8ff | 579 | { |
| bogdanm | 0:9b334a45a8ff | 580 | __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_RESET); |
| bogdanm | 0:9b334a45a8ff | 581 | HAL_PCD_ResetCallback(hpcd); |
| bogdanm | 0:9b334a45a8ff | 582 | HAL_PCD_SetAddress(hpcd, 0); |
| bogdanm | 0:9b334a45a8ff | 583 | } |
| bogdanm | 0:9b334a45a8ff | 584 | |
| bogdanm | 0:9b334a45a8ff | 585 | if (__HAL_PCD_GET_FLAG (hpcd, USB_ISTR_PMAOVR)) |
| bogdanm | 0:9b334a45a8ff | 586 | { |
| bogdanm | 0:9b334a45a8ff | 587 | __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_PMAOVR); |
| bogdanm | 0:9b334a45a8ff | 588 | } |
| bogdanm | 0:9b334a45a8ff | 589 | if (__HAL_PCD_GET_FLAG (hpcd, USB_ISTR_ERR)) |
| bogdanm | 0:9b334a45a8ff | 590 | { |
| bogdanm | 0:9b334a45a8ff | 591 | __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_ERR); |
| bogdanm | 0:9b334a45a8ff | 592 | } |
| bogdanm | 0:9b334a45a8ff | 593 | |
| bogdanm | 0:9b334a45a8ff | 594 | if (__HAL_PCD_GET_FLAG (hpcd, USB_ISTR_WKUP)) |
| bogdanm | 0:9b334a45a8ff | 595 | { |
| bogdanm | 0:9b334a45a8ff | 596 | hpcd->Instance->CNTR &= ~(USB_CNTR_LP_MODE); |
| bogdanm | 0:9b334a45a8ff | 597 | |
| bogdanm | 0:9b334a45a8ff | 598 | /*set wInterrupt_Mask global variable*/ |
| bogdanm | 0:9b334a45a8ff | 599 | wInterrupt_Mask = USB_CNTR_CTRM | USB_CNTR_WKUPM | USB_CNTR_SUSPM | USB_CNTR_ERRM \ |
| bogdanm | 0:9b334a45a8ff | 600 | | USB_CNTR_ESOFM | USB_CNTR_RESETM; |
| bogdanm | 0:9b334a45a8ff | 601 | |
| bogdanm | 0:9b334a45a8ff | 602 | /*Set interrupt mask*/ |
| bogdanm | 0:9b334a45a8ff | 603 | hpcd->Instance->CNTR = wInterrupt_Mask; |
| bogdanm | 0:9b334a45a8ff | 604 | |
| bogdanm | 0:9b334a45a8ff | 605 | HAL_PCD_ResumeCallback(hpcd); |
| bogdanm | 0:9b334a45a8ff | 606 | |
| bogdanm | 0:9b334a45a8ff | 607 | __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_WKUP); |
| bogdanm | 0:9b334a45a8ff | 608 | } |
| bogdanm | 0:9b334a45a8ff | 609 | |
| bogdanm | 0:9b334a45a8ff | 610 | if (__HAL_PCD_GET_FLAG (hpcd, USB_ISTR_SUSP)) |
| bogdanm | 0:9b334a45a8ff | 611 | { |
| bogdanm | 0:9b334a45a8ff | 612 | /* clear of the ISTR bit must be done after setting of CNTR_FSUSP */ |
| bogdanm | 0:9b334a45a8ff | 613 | __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_SUSP); |
| bogdanm | 0:9b334a45a8ff | 614 | |
| bogdanm | 0:9b334a45a8ff | 615 | /* Force low-power mode in the macrocell */ |
| bogdanm | 0:9b334a45a8ff | 616 | hpcd->Instance->CNTR |= USB_CNTR_FSUSP; |
| bogdanm | 0:9b334a45a8ff | 617 | hpcd->Instance->CNTR |= USB_CNTR_LP_MODE; |
| bogdanm | 0:9b334a45a8ff | 618 | if (__HAL_PCD_GET_FLAG (hpcd, USB_ISTR_WKUP) == 0) |
| bogdanm | 0:9b334a45a8ff | 619 | { |
| bogdanm | 0:9b334a45a8ff | 620 | HAL_PCD_SuspendCallback(hpcd); |
| bogdanm | 0:9b334a45a8ff | 621 | } |
| bogdanm | 0:9b334a45a8ff | 622 | } |
| bogdanm | 0:9b334a45a8ff | 623 | |
| bogdanm | 0:9b334a45a8ff | 624 | if (__HAL_PCD_GET_FLAG (hpcd, USB_ISTR_SOF)) |
| bogdanm | 0:9b334a45a8ff | 625 | { |
| bogdanm | 0:9b334a45a8ff | 626 | __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_SOF); |
| bogdanm | 0:9b334a45a8ff | 627 | HAL_PCD_SOFCallback(hpcd); |
| bogdanm | 0:9b334a45a8ff | 628 | } |
| bogdanm | 0:9b334a45a8ff | 629 | |
| bogdanm | 0:9b334a45a8ff | 630 | if (__HAL_PCD_GET_FLAG (hpcd, USB_ISTR_ESOF)) |
| bogdanm | 0:9b334a45a8ff | 631 | { |
| bogdanm | 0:9b334a45a8ff | 632 | /* clear ESOF flag in ISTR */ |
| bogdanm | 0:9b334a45a8ff | 633 | __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_ESOF); |
| bogdanm | 0:9b334a45a8ff | 634 | } |
| bogdanm | 0:9b334a45a8ff | 635 | } |
| bogdanm | 0:9b334a45a8ff | 636 | #endif /* USB */ |
| bogdanm | 0:9b334a45a8ff | 637 | |
| bogdanm | 0:9b334a45a8ff | 638 | /** |
| bogdanm | 0:9b334a45a8ff | 639 | * @brief Data out stage callbacks |
| bogdanm | 0:9b334a45a8ff | 640 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 641 | * @param epnum: endpoint number |
| bogdanm | 0:9b334a45a8ff | 642 | * @retval None |
| bogdanm | 0:9b334a45a8ff | 643 | */ |
| bogdanm | 0:9b334a45a8ff | 644 | __weak void HAL_PCD_DataOutStageCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum) |
| bogdanm | 0:9b334a45a8ff | 645 | { |
| bogdanm | 0:9b334a45a8ff | 646 | /* NOTE : This function should not be modified, when the callback is needed, |
| bogdanm | 0:9b334a45a8ff | 647 | the HAL_PCD_DataOutStageCallback could be implemented in the user file |
| bogdanm | 0:9b334a45a8ff | 648 | */ |
| bogdanm | 0:9b334a45a8ff | 649 | } |
| bogdanm | 0:9b334a45a8ff | 650 | |
| bogdanm | 0:9b334a45a8ff | 651 | /** |
| bogdanm | 0:9b334a45a8ff | 652 | * @brief Data IN stage callbacks |
| bogdanm | 0:9b334a45a8ff | 653 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 654 | * @param epnum: endpoint number |
| bogdanm | 0:9b334a45a8ff | 655 | * @retval None |
| bogdanm | 0:9b334a45a8ff | 656 | */ |
| bogdanm | 0:9b334a45a8ff | 657 | __weak void HAL_PCD_DataInStageCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum) |
| bogdanm | 0:9b334a45a8ff | 658 | { |
| bogdanm | 0:9b334a45a8ff | 659 | /* NOTE : This function should not be modified, when the callback is needed, |
| bogdanm | 0:9b334a45a8ff | 660 | the HAL_PCD_DataInStageCallback could be implemented in the user file |
| bogdanm | 0:9b334a45a8ff | 661 | */ |
| bogdanm | 0:9b334a45a8ff | 662 | } |
| bogdanm | 0:9b334a45a8ff | 663 | /** |
| bogdanm | 0:9b334a45a8ff | 664 | * @brief Setup stage callback |
| bogdanm | 0:9b334a45a8ff | 665 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 666 | * @retval None |
| bogdanm | 0:9b334a45a8ff | 667 | */ |
| bogdanm | 0:9b334a45a8ff | 668 | __weak void HAL_PCD_SetupStageCallback(PCD_HandleTypeDef *hpcd) |
| bogdanm | 0:9b334a45a8ff | 669 | { |
| bogdanm | 0:9b334a45a8ff | 670 | /* NOTE : This function should not be modified, when the callback is needed, |
| bogdanm | 0:9b334a45a8ff | 671 | the HAL_PCD_SetupStageCallback could be implemented in the user file |
| bogdanm | 0:9b334a45a8ff | 672 | */ |
| bogdanm | 0:9b334a45a8ff | 673 | } |
| bogdanm | 0:9b334a45a8ff | 674 | |
| bogdanm | 0:9b334a45a8ff | 675 | /** |
| bogdanm | 0:9b334a45a8ff | 676 | * @brief USB Start Of Frame callbacks |
| bogdanm | 0:9b334a45a8ff | 677 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 678 | * @retval None |
| bogdanm | 0:9b334a45a8ff | 679 | */ |
| bogdanm | 0:9b334a45a8ff | 680 | __weak void HAL_PCD_SOFCallback(PCD_HandleTypeDef *hpcd) |
| bogdanm | 0:9b334a45a8ff | 681 | { |
| bogdanm | 0:9b334a45a8ff | 682 | /* NOTE : This function should not be modified, when the callback is needed, |
| bogdanm | 0:9b334a45a8ff | 683 | the HAL_PCD_SOFCallback could be implemented in the user file |
| bogdanm | 0:9b334a45a8ff | 684 | */ |
| bogdanm | 0:9b334a45a8ff | 685 | } |
| bogdanm | 0:9b334a45a8ff | 686 | |
| bogdanm | 0:9b334a45a8ff | 687 | /** |
| bogdanm | 0:9b334a45a8ff | 688 | * @brief USB Reset callbacks |
| bogdanm | 0:9b334a45a8ff | 689 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 690 | * @retval None |
| bogdanm | 0:9b334a45a8ff | 691 | */ |
| bogdanm | 0:9b334a45a8ff | 692 | __weak void HAL_PCD_ResetCallback(PCD_HandleTypeDef *hpcd) |
| bogdanm | 0:9b334a45a8ff | 693 | { |
| bogdanm | 0:9b334a45a8ff | 694 | /* NOTE : This function should not be modified, when the callback is needed, |
| bogdanm | 0:9b334a45a8ff | 695 | the HAL_PCD_ResetCallback could be implemented in the user file |
| bogdanm | 0:9b334a45a8ff | 696 | */ |
| bogdanm | 0:9b334a45a8ff | 697 | } |
| bogdanm | 0:9b334a45a8ff | 698 | |
| bogdanm | 0:9b334a45a8ff | 699 | /** |
| bogdanm | 0:9b334a45a8ff | 700 | * @brief Suspend event callbacks |
| bogdanm | 0:9b334a45a8ff | 701 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 702 | * @retval None |
| bogdanm | 0:9b334a45a8ff | 703 | */ |
| bogdanm | 0:9b334a45a8ff | 704 | __weak void HAL_PCD_SuspendCallback(PCD_HandleTypeDef *hpcd) |
| bogdanm | 0:9b334a45a8ff | 705 | { |
| bogdanm | 0:9b334a45a8ff | 706 | /* NOTE : This function should not be modified, when the callback is needed, |
| bogdanm | 0:9b334a45a8ff | 707 | the HAL_PCD_SuspendCallback could be implemented in the user file |
| bogdanm | 0:9b334a45a8ff | 708 | */ |
| bogdanm | 0:9b334a45a8ff | 709 | } |
| bogdanm | 0:9b334a45a8ff | 710 | |
| bogdanm | 0:9b334a45a8ff | 711 | /** |
| bogdanm | 0:9b334a45a8ff | 712 | * @brief Resume event callbacks |
| bogdanm | 0:9b334a45a8ff | 713 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 714 | * @retval None |
| bogdanm | 0:9b334a45a8ff | 715 | */ |
| bogdanm | 0:9b334a45a8ff | 716 | __weak void HAL_PCD_ResumeCallback(PCD_HandleTypeDef *hpcd) |
| bogdanm | 0:9b334a45a8ff | 717 | { |
| bogdanm | 0:9b334a45a8ff | 718 | /* NOTE : This function should not be modified, when the callback is needed, |
| bogdanm | 0:9b334a45a8ff | 719 | the HAL_PCD_ResumeCallback could be implemented in the user file |
| bogdanm | 0:9b334a45a8ff | 720 | */ |
| bogdanm | 0:9b334a45a8ff | 721 | } |
| bogdanm | 0:9b334a45a8ff | 722 | |
| bogdanm | 0:9b334a45a8ff | 723 | /** |
| bogdanm | 0:9b334a45a8ff | 724 | * @brief Incomplete ISO OUT callbacks |
| bogdanm | 0:9b334a45a8ff | 725 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 726 | * @param epnum: endpoint number |
| bogdanm | 0:9b334a45a8ff | 727 | * @retval None |
| bogdanm | 0:9b334a45a8ff | 728 | */ |
| bogdanm | 0:9b334a45a8ff | 729 | __weak void HAL_PCD_ISOOUTIncompleteCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum) |
| bogdanm | 0:9b334a45a8ff | 730 | { |
| bogdanm | 0:9b334a45a8ff | 731 | /* NOTE : This function should not be modified, when the callback is needed, |
| bogdanm | 0:9b334a45a8ff | 732 | the HAL_PCD_ISOOUTIncompleteCallback could be implemented in the user file |
| bogdanm | 0:9b334a45a8ff | 733 | */ |
| bogdanm | 0:9b334a45a8ff | 734 | } |
| bogdanm | 0:9b334a45a8ff | 735 | |
| bogdanm | 0:9b334a45a8ff | 736 | /** |
| bogdanm | 0:9b334a45a8ff | 737 | * @brief Incomplete ISO IN callbacks |
| bogdanm | 0:9b334a45a8ff | 738 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 739 | * @param epnum: endpoint number |
| bogdanm | 0:9b334a45a8ff | 740 | * @retval None |
| bogdanm | 0:9b334a45a8ff | 741 | */ |
| bogdanm | 0:9b334a45a8ff | 742 | __weak void HAL_PCD_ISOINIncompleteCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum) |
| bogdanm | 0:9b334a45a8ff | 743 | { |
| bogdanm | 0:9b334a45a8ff | 744 | /* NOTE : This function should not be modified, when the callback is needed, |
| bogdanm | 0:9b334a45a8ff | 745 | the HAL_PCD_ISOINIncompleteCallback could be implemented in the user file |
| bogdanm | 0:9b334a45a8ff | 746 | */ |
| bogdanm | 0:9b334a45a8ff | 747 | } |
| bogdanm | 0:9b334a45a8ff | 748 | |
| bogdanm | 0:9b334a45a8ff | 749 | /** |
| bogdanm | 0:9b334a45a8ff | 750 | * @brief Connection event callbacks |
| bogdanm | 0:9b334a45a8ff | 751 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 752 | * @retval None |
| bogdanm | 0:9b334a45a8ff | 753 | */ |
| bogdanm | 0:9b334a45a8ff | 754 | __weak void HAL_PCD_ConnectCallback(PCD_HandleTypeDef *hpcd) |
| bogdanm | 0:9b334a45a8ff | 755 | { |
| bogdanm | 0:9b334a45a8ff | 756 | /* NOTE : This function should not be modified, when the callback is needed, |
| bogdanm | 0:9b334a45a8ff | 757 | the HAL_PCD_ConnectCallback could be implemented in the user file |
| bogdanm | 0:9b334a45a8ff | 758 | */ |
| bogdanm | 0:9b334a45a8ff | 759 | } |
| bogdanm | 0:9b334a45a8ff | 760 | |
| bogdanm | 0:9b334a45a8ff | 761 | /** |
| bogdanm | 0:9b334a45a8ff | 762 | * @brief Disconnection event callbacks |
| bogdanm | 0:9b334a45a8ff | 763 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 764 | * @retval None |
| bogdanm | 0:9b334a45a8ff | 765 | */ |
| bogdanm | 0:9b334a45a8ff | 766 | __weak void HAL_PCD_DisconnectCallback(PCD_HandleTypeDef *hpcd) |
| bogdanm | 0:9b334a45a8ff | 767 | { |
| bogdanm | 0:9b334a45a8ff | 768 | /* NOTE : This function should not be modified, when the callback is needed, |
| bogdanm | 0:9b334a45a8ff | 769 | the HAL_PCD_DisconnectCallback could be implemented in the user file |
| bogdanm | 0:9b334a45a8ff | 770 | */ |
| bogdanm | 0:9b334a45a8ff | 771 | } |
| bogdanm | 0:9b334a45a8ff | 772 | |
| bogdanm | 0:9b334a45a8ff | 773 | /** |
| bogdanm | 0:9b334a45a8ff | 774 | * @} |
| bogdanm | 0:9b334a45a8ff | 775 | */ |
| bogdanm | 0:9b334a45a8ff | 776 | |
| bogdanm | 0:9b334a45a8ff | 777 | /** @defgroup PCD_Exported_Functions_Group3 Peripheral Control functions |
| bogdanm | 0:9b334a45a8ff | 778 | * @brief management functions |
| bogdanm | 0:9b334a45a8ff | 779 | * |
| bogdanm | 0:9b334a45a8ff | 780 | @verbatim |
| bogdanm | 0:9b334a45a8ff | 781 | =============================================================================== |
| bogdanm | 0:9b334a45a8ff | 782 | ##### Peripheral Control functions ##### |
| bogdanm | 0:9b334a45a8ff | 783 | =============================================================================== |
| bogdanm | 0:9b334a45a8ff | 784 | [..] |
| bogdanm | 0:9b334a45a8ff | 785 | This subsection provides a set of functions allowing to control the PCD data |
| bogdanm | 0:9b334a45a8ff | 786 | transfers. |
| bogdanm | 0:9b334a45a8ff | 787 | |
| bogdanm | 0:9b334a45a8ff | 788 | @endverbatim |
| bogdanm | 0:9b334a45a8ff | 789 | * @{ |
| bogdanm | 0:9b334a45a8ff | 790 | */ |
| bogdanm | 0:9b334a45a8ff | 791 | |
| bogdanm | 0:9b334a45a8ff | 792 | /** |
| bogdanm | 0:9b334a45a8ff | 793 | * @brief Connect the USB device |
| bogdanm | 0:9b334a45a8ff | 794 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 795 | * @retval HAL status |
| bogdanm | 0:9b334a45a8ff | 796 | */ |
| bogdanm | 0:9b334a45a8ff | 797 | HAL_StatusTypeDef HAL_PCD_DevConnect(PCD_HandleTypeDef *hpcd) |
| bogdanm | 0:9b334a45a8ff | 798 | { |
| bogdanm | 0:9b334a45a8ff | 799 | __HAL_LOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 800 | HAL_PCDEx_SetConnectionState (hpcd, 1); |
| bogdanm | 0:9b334a45a8ff | 801 | USB_DevConnect(hpcd->Instance); |
| bogdanm | 0:9b334a45a8ff | 802 | __HAL_UNLOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 803 | return HAL_OK; |
| bogdanm | 0:9b334a45a8ff | 804 | } |
| bogdanm | 0:9b334a45a8ff | 805 | |
| bogdanm | 0:9b334a45a8ff | 806 | /** |
| bogdanm | 0:9b334a45a8ff | 807 | * @brief Disconnect the USB device |
| bogdanm | 0:9b334a45a8ff | 808 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 809 | * @retval HAL status |
| bogdanm | 0:9b334a45a8ff | 810 | */ |
| bogdanm | 0:9b334a45a8ff | 811 | HAL_StatusTypeDef HAL_PCD_DevDisconnect(PCD_HandleTypeDef *hpcd) |
| bogdanm | 0:9b334a45a8ff | 812 | { |
| bogdanm | 0:9b334a45a8ff | 813 | __HAL_LOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 814 | HAL_PCDEx_SetConnectionState (hpcd, 0); |
| bogdanm | 0:9b334a45a8ff | 815 | USB_DevDisconnect(hpcd->Instance); |
| bogdanm | 0:9b334a45a8ff | 816 | __HAL_UNLOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 817 | return HAL_OK; |
| bogdanm | 0:9b334a45a8ff | 818 | } |
| bogdanm | 0:9b334a45a8ff | 819 | |
| bogdanm | 0:9b334a45a8ff | 820 | /** |
| bogdanm | 0:9b334a45a8ff | 821 | * @brief Set the USB Device address |
| bogdanm | 0:9b334a45a8ff | 822 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 823 | * @param address: new device address |
| bogdanm | 0:9b334a45a8ff | 824 | * @retval HAL status |
| bogdanm | 0:9b334a45a8ff | 825 | */ |
| bogdanm | 0:9b334a45a8ff | 826 | HAL_StatusTypeDef HAL_PCD_SetAddress(PCD_HandleTypeDef *hpcd, uint8_t address) |
| bogdanm | 0:9b334a45a8ff | 827 | { |
| bogdanm | 0:9b334a45a8ff | 828 | __HAL_LOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 829 | hpcd->USB_Address = address; |
| bogdanm | 0:9b334a45a8ff | 830 | USB_SetDevAddress(hpcd->Instance, address); |
| bogdanm | 0:9b334a45a8ff | 831 | __HAL_UNLOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 832 | return HAL_OK; |
| bogdanm | 0:9b334a45a8ff | 833 | } |
| bogdanm | 0:9b334a45a8ff | 834 | /** |
| bogdanm | 0:9b334a45a8ff | 835 | * @brief Open and configure an endpoint |
| bogdanm | 0:9b334a45a8ff | 836 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 837 | * @param ep_addr: endpoint address |
| bogdanm | 0:9b334a45a8ff | 838 | * @param ep_mps: endpoint max packet size |
| bogdanm | 0:9b334a45a8ff | 839 | * @param ep_type: endpoint type |
| bogdanm | 0:9b334a45a8ff | 840 | * @retval HAL status |
| bogdanm | 0:9b334a45a8ff | 841 | */ |
| bogdanm | 0:9b334a45a8ff | 842 | HAL_StatusTypeDef HAL_PCD_EP_Open(PCD_HandleTypeDef *hpcd, uint8_t ep_addr, uint16_t ep_mps, uint8_t ep_type) |
| bogdanm | 0:9b334a45a8ff | 843 | { |
| bogdanm | 0:9b334a45a8ff | 844 | HAL_StatusTypeDef ret = HAL_OK; |
| bogdanm | 0:9b334a45a8ff | 845 | PCD_EPTypeDef *ep = NULL; |
| bogdanm | 0:9b334a45a8ff | 846 | |
| bogdanm | 0:9b334a45a8ff | 847 | if ((ep_addr & 0x80) == 0x80) |
| bogdanm | 0:9b334a45a8ff | 848 | { |
| bogdanm | 0:9b334a45a8ff | 849 | ep = &hpcd->IN_ep[ep_addr & 0x7F]; |
| bogdanm | 0:9b334a45a8ff | 850 | } |
| bogdanm | 0:9b334a45a8ff | 851 | else |
| bogdanm | 0:9b334a45a8ff | 852 | { |
| bogdanm | 0:9b334a45a8ff | 853 | ep = &hpcd->OUT_ep[ep_addr & 0x7F]; |
| bogdanm | 0:9b334a45a8ff | 854 | } |
| bogdanm | 0:9b334a45a8ff | 855 | ep->num = ep_addr & 0x7F; |
| bogdanm | 0:9b334a45a8ff | 856 | |
| bogdanm | 0:9b334a45a8ff | 857 | ep->is_in = (0x80 & ep_addr) != 0; |
| bogdanm | 0:9b334a45a8ff | 858 | ep->maxpacket = ep_mps; |
| bogdanm | 0:9b334a45a8ff | 859 | ep->type = ep_type; |
| bogdanm | 0:9b334a45a8ff | 860 | |
| bogdanm | 0:9b334a45a8ff | 861 | __HAL_LOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 862 | USB_ActivateEndpoint(hpcd->Instance , ep); |
| bogdanm | 0:9b334a45a8ff | 863 | __HAL_UNLOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 864 | return ret; |
| bogdanm | 0:9b334a45a8ff | 865 | } |
| bogdanm | 0:9b334a45a8ff | 866 | |
| bogdanm | 0:9b334a45a8ff | 867 | /** |
| bogdanm | 0:9b334a45a8ff | 868 | * @brief Deactivate an endpoint |
| bogdanm | 0:9b334a45a8ff | 869 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 870 | * @param ep_addr: endpoint address |
| bogdanm | 0:9b334a45a8ff | 871 | * @retval HAL status |
| bogdanm | 0:9b334a45a8ff | 872 | */ |
| bogdanm | 0:9b334a45a8ff | 873 | HAL_StatusTypeDef HAL_PCD_EP_Close(PCD_HandleTypeDef *hpcd, uint8_t ep_addr) |
| bogdanm | 0:9b334a45a8ff | 874 | { |
| bogdanm | 0:9b334a45a8ff | 875 | PCD_EPTypeDef *ep = NULL; |
| bogdanm | 0:9b334a45a8ff | 876 | |
| bogdanm | 0:9b334a45a8ff | 877 | if ((ep_addr & 0x80) == 0x80) |
| bogdanm | 0:9b334a45a8ff | 878 | { |
| bogdanm | 0:9b334a45a8ff | 879 | ep = &hpcd->IN_ep[ep_addr & 0x7F]; |
| bogdanm | 0:9b334a45a8ff | 880 | } |
| bogdanm | 0:9b334a45a8ff | 881 | else |
| bogdanm | 0:9b334a45a8ff | 882 | { |
| bogdanm | 0:9b334a45a8ff | 883 | ep = &hpcd->OUT_ep[ep_addr & 0x7F]; |
| bogdanm | 0:9b334a45a8ff | 884 | } |
| bogdanm | 0:9b334a45a8ff | 885 | ep->num = ep_addr & 0x7F; |
| bogdanm | 0:9b334a45a8ff | 886 | |
| bogdanm | 0:9b334a45a8ff | 887 | ep->is_in = (0x80 & ep_addr) != 0; |
| bogdanm | 0:9b334a45a8ff | 888 | |
| bogdanm | 0:9b334a45a8ff | 889 | __HAL_LOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 890 | USB_DeactivateEndpoint(hpcd->Instance , ep); |
| bogdanm | 0:9b334a45a8ff | 891 | __HAL_UNLOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 892 | return HAL_OK; |
| bogdanm | 0:9b334a45a8ff | 893 | } |
| bogdanm | 0:9b334a45a8ff | 894 | |
| bogdanm | 0:9b334a45a8ff | 895 | |
| bogdanm | 0:9b334a45a8ff | 896 | /** |
| bogdanm | 0:9b334a45a8ff | 897 | * @brief Receive an amount of data |
| bogdanm | 0:9b334a45a8ff | 898 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 899 | * @param ep_addr: endpoint address |
| bogdanm | 0:9b334a45a8ff | 900 | * @param pBuf: pointer to the reception buffer |
| bogdanm | 0:9b334a45a8ff | 901 | * @param len: amount of data to be received |
| bogdanm | 0:9b334a45a8ff | 902 | * @retval HAL status |
| bogdanm | 0:9b334a45a8ff | 903 | */ |
| bogdanm | 0:9b334a45a8ff | 904 | HAL_StatusTypeDef HAL_PCD_EP_Receive(PCD_HandleTypeDef *hpcd, uint8_t ep_addr, uint8_t *pBuf, uint32_t len) |
| bogdanm | 0:9b334a45a8ff | 905 | { |
| bogdanm | 0:9b334a45a8ff | 906 | PCD_EPTypeDef *ep = NULL; |
| bogdanm | 0:9b334a45a8ff | 907 | |
| bogdanm | 0:9b334a45a8ff | 908 | ep = &hpcd->OUT_ep[ep_addr & 0x7F]; |
| bogdanm | 0:9b334a45a8ff | 909 | |
| bogdanm | 0:9b334a45a8ff | 910 | /*setup and start the Xfer */ |
| bogdanm | 0:9b334a45a8ff | 911 | ep->xfer_buff = pBuf; |
| bogdanm | 0:9b334a45a8ff | 912 | ep->xfer_len = len; |
| bogdanm | 0:9b334a45a8ff | 913 | ep->xfer_count = 0; |
| bogdanm | 0:9b334a45a8ff | 914 | ep->is_in = 0; |
| bogdanm | 0:9b334a45a8ff | 915 | ep->num = ep_addr & 0x7F; |
| bogdanm | 0:9b334a45a8ff | 916 | |
| bogdanm | 0:9b334a45a8ff | 917 | __HAL_LOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 918 | |
| bogdanm | 0:9b334a45a8ff | 919 | if ((ep_addr & 0x7F) == 0 ) |
| bogdanm | 0:9b334a45a8ff | 920 | { |
| bogdanm | 0:9b334a45a8ff | 921 | USB_EP0StartXfer(hpcd->Instance , ep); |
| bogdanm | 0:9b334a45a8ff | 922 | } |
| bogdanm | 0:9b334a45a8ff | 923 | else |
| bogdanm | 0:9b334a45a8ff | 924 | { |
| bogdanm | 0:9b334a45a8ff | 925 | USB_EPStartXfer(hpcd->Instance , ep); |
| bogdanm | 0:9b334a45a8ff | 926 | } |
| bogdanm | 0:9b334a45a8ff | 927 | __HAL_UNLOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 928 | |
| bogdanm | 0:9b334a45a8ff | 929 | return HAL_OK; |
| bogdanm | 0:9b334a45a8ff | 930 | } |
| bogdanm | 0:9b334a45a8ff | 931 | |
| bogdanm | 0:9b334a45a8ff | 932 | /** |
| bogdanm | 0:9b334a45a8ff | 933 | * @brief Get Received Data Size |
| bogdanm | 0:9b334a45a8ff | 934 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 935 | * @param ep_addr: endpoint address |
| bogdanm | 0:9b334a45a8ff | 936 | * @retval Data Size |
| bogdanm | 0:9b334a45a8ff | 937 | */ |
| bogdanm | 0:9b334a45a8ff | 938 | uint16_t HAL_PCD_EP_GetRxCount(PCD_HandleTypeDef *hpcd, uint8_t ep_addr) |
| bogdanm | 0:9b334a45a8ff | 939 | { |
| bogdanm | 0:9b334a45a8ff | 940 | return hpcd->OUT_ep[ep_addr & 0x7F].xfer_count; |
| bogdanm | 0:9b334a45a8ff | 941 | } |
| bogdanm | 0:9b334a45a8ff | 942 | /** |
| bogdanm | 0:9b334a45a8ff | 943 | * @brief Send an amount of data |
| bogdanm | 0:9b334a45a8ff | 944 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 945 | * @param ep_addr: endpoint address |
| bogdanm | 0:9b334a45a8ff | 946 | * @param pBuf: pointer to the transmission buffer |
| bogdanm | 0:9b334a45a8ff | 947 | * @param len: amount of data to be sent |
| bogdanm | 0:9b334a45a8ff | 948 | * @retval HAL status |
| bogdanm | 0:9b334a45a8ff | 949 | */ |
| bogdanm | 0:9b334a45a8ff | 950 | HAL_StatusTypeDef HAL_PCD_EP_Transmit(PCD_HandleTypeDef *hpcd, uint8_t ep_addr, uint8_t *pBuf, uint32_t len) |
| bogdanm | 0:9b334a45a8ff | 951 | { |
| bogdanm | 0:9b334a45a8ff | 952 | PCD_EPTypeDef *ep = NULL; |
| bogdanm | 0:9b334a45a8ff | 953 | |
| bogdanm | 0:9b334a45a8ff | 954 | ep = &hpcd->IN_ep[ep_addr & 0x7F]; |
| bogdanm | 0:9b334a45a8ff | 955 | |
| bogdanm | 0:9b334a45a8ff | 956 | /*setup and start the Xfer */ |
| bogdanm | 0:9b334a45a8ff | 957 | ep->xfer_buff = pBuf; |
| bogdanm | 0:9b334a45a8ff | 958 | ep->xfer_len = len; |
| bogdanm | 0:9b334a45a8ff | 959 | ep->xfer_count = 0; |
| bogdanm | 0:9b334a45a8ff | 960 | ep->is_in = 1; |
| bogdanm | 0:9b334a45a8ff | 961 | ep->num = ep_addr & 0x7F; |
| bogdanm | 0:9b334a45a8ff | 962 | |
| bogdanm | 0:9b334a45a8ff | 963 | __HAL_LOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 964 | |
| bogdanm | 0:9b334a45a8ff | 965 | if ((ep_addr & 0x7F) == 0 ) |
| bogdanm | 0:9b334a45a8ff | 966 | { |
| bogdanm | 0:9b334a45a8ff | 967 | USB_EP0StartXfer(hpcd->Instance , ep); |
| bogdanm | 0:9b334a45a8ff | 968 | } |
| bogdanm | 0:9b334a45a8ff | 969 | else |
| bogdanm | 0:9b334a45a8ff | 970 | { |
| bogdanm | 0:9b334a45a8ff | 971 | USB_EPStartXfer(hpcd->Instance , ep); |
| bogdanm | 0:9b334a45a8ff | 972 | } |
| bogdanm | 0:9b334a45a8ff | 973 | |
| bogdanm | 0:9b334a45a8ff | 974 | __HAL_UNLOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 975 | |
| bogdanm | 0:9b334a45a8ff | 976 | return HAL_OK; |
| bogdanm | 0:9b334a45a8ff | 977 | } |
| bogdanm | 0:9b334a45a8ff | 978 | |
| bogdanm | 0:9b334a45a8ff | 979 | /** |
| bogdanm | 0:9b334a45a8ff | 980 | * @brief Set a STALL condition over an endpoint |
| bogdanm | 0:9b334a45a8ff | 981 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 982 | * @param ep_addr: endpoint address |
| bogdanm | 0:9b334a45a8ff | 983 | * @retval HAL status |
| bogdanm | 0:9b334a45a8ff | 984 | */ |
| bogdanm | 0:9b334a45a8ff | 985 | HAL_StatusTypeDef HAL_PCD_EP_SetStall(PCD_HandleTypeDef *hpcd, uint8_t ep_addr) |
| bogdanm | 0:9b334a45a8ff | 986 | { |
| bogdanm | 0:9b334a45a8ff | 987 | PCD_EPTypeDef *ep = NULL; |
| bogdanm | 0:9b334a45a8ff | 988 | |
| bogdanm | 0:9b334a45a8ff | 989 | if ((0x80 & ep_addr) == 0x80) |
| bogdanm | 0:9b334a45a8ff | 990 | { |
| bogdanm | 0:9b334a45a8ff | 991 | ep = &hpcd->IN_ep[ep_addr & 0x7F]; |
| bogdanm | 0:9b334a45a8ff | 992 | } |
| bogdanm | 0:9b334a45a8ff | 993 | else |
| bogdanm | 0:9b334a45a8ff | 994 | { |
| bogdanm | 0:9b334a45a8ff | 995 | ep = &hpcd->OUT_ep[ep_addr]; |
| bogdanm | 0:9b334a45a8ff | 996 | } |
| bogdanm | 0:9b334a45a8ff | 997 | |
| bogdanm | 0:9b334a45a8ff | 998 | ep->is_stall = 1; |
| bogdanm | 0:9b334a45a8ff | 999 | ep->num = ep_addr & 0x7F; |
| bogdanm | 0:9b334a45a8ff | 1000 | ep->is_in = ((ep_addr & 0x80) == 0x80); |
| bogdanm | 0:9b334a45a8ff | 1001 | |
| bogdanm | 0:9b334a45a8ff | 1002 | __HAL_LOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 1003 | USB_EPSetStall(hpcd->Instance , ep); |
| bogdanm | 0:9b334a45a8ff | 1004 | if((ep_addr & 0x7F) == 0) |
| bogdanm | 0:9b334a45a8ff | 1005 | { |
| bogdanm | 0:9b334a45a8ff | 1006 | USB_EP0_OutStart(hpcd->Instance, (uint8_t *)hpcd->Setup); |
| bogdanm | 0:9b334a45a8ff | 1007 | } |
| bogdanm | 0:9b334a45a8ff | 1008 | __HAL_UNLOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 1009 | |
| bogdanm | 0:9b334a45a8ff | 1010 | return HAL_OK; |
| bogdanm | 0:9b334a45a8ff | 1011 | } |
| bogdanm | 0:9b334a45a8ff | 1012 | |
| bogdanm | 0:9b334a45a8ff | 1013 | /** |
| bogdanm | 0:9b334a45a8ff | 1014 | * @brief Clear a STALL condition over in an endpoint |
| bogdanm | 0:9b334a45a8ff | 1015 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 1016 | * @param ep_addr: endpoint address |
| bogdanm | 0:9b334a45a8ff | 1017 | * @retval HAL status |
| bogdanm | 0:9b334a45a8ff | 1018 | */ |
| bogdanm | 0:9b334a45a8ff | 1019 | HAL_StatusTypeDef HAL_PCD_EP_ClrStall(PCD_HandleTypeDef *hpcd, uint8_t ep_addr) |
| bogdanm | 0:9b334a45a8ff | 1020 | { |
| bogdanm | 0:9b334a45a8ff | 1021 | PCD_EPTypeDef *ep = NULL; |
| bogdanm | 0:9b334a45a8ff | 1022 | |
| bogdanm | 0:9b334a45a8ff | 1023 | if ((0x80 & ep_addr) == 0x80) |
| bogdanm | 0:9b334a45a8ff | 1024 | { |
| bogdanm | 0:9b334a45a8ff | 1025 | ep = &hpcd->IN_ep[ep_addr & 0x7F]; |
| bogdanm | 0:9b334a45a8ff | 1026 | } |
| bogdanm | 0:9b334a45a8ff | 1027 | else |
| bogdanm | 0:9b334a45a8ff | 1028 | { |
| bogdanm | 0:9b334a45a8ff | 1029 | ep = &hpcd->OUT_ep[ep_addr]; |
| bogdanm | 0:9b334a45a8ff | 1030 | } |
| bogdanm | 0:9b334a45a8ff | 1031 | |
| bogdanm | 0:9b334a45a8ff | 1032 | ep->is_stall = 0; |
| bogdanm | 0:9b334a45a8ff | 1033 | ep->num = ep_addr & 0x7F; |
| bogdanm | 0:9b334a45a8ff | 1034 | ep->is_in = ((ep_addr & 0x80) == 0x80); |
| bogdanm | 0:9b334a45a8ff | 1035 | |
| bogdanm | 0:9b334a45a8ff | 1036 | __HAL_LOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 1037 | USB_EPClearStall(hpcd->Instance , ep); |
| bogdanm | 0:9b334a45a8ff | 1038 | __HAL_UNLOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 1039 | |
| bogdanm | 0:9b334a45a8ff | 1040 | return HAL_OK; |
| bogdanm | 0:9b334a45a8ff | 1041 | } |
| bogdanm | 0:9b334a45a8ff | 1042 | |
| bogdanm | 0:9b334a45a8ff | 1043 | /** |
| bogdanm | 0:9b334a45a8ff | 1044 | * @brief Flush an endpoint |
| bogdanm | 0:9b334a45a8ff | 1045 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 1046 | * @param ep_addr: endpoint address |
| bogdanm | 0:9b334a45a8ff | 1047 | * @retval HAL status |
| bogdanm | 0:9b334a45a8ff | 1048 | */ |
| bogdanm | 0:9b334a45a8ff | 1049 | HAL_StatusTypeDef HAL_PCD_EP_Flush(PCD_HandleTypeDef *hpcd, uint8_t ep_addr) |
| bogdanm | 0:9b334a45a8ff | 1050 | { |
| bogdanm | 0:9b334a45a8ff | 1051 | __HAL_LOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 1052 | |
| bogdanm | 0:9b334a45a8ff | 1053 | if ((ep_addr & 0x80) == 0x80) |
| bogdanm | 0:9b334a45a8ff | 1054 | { |
| bogdanm | 0:9b334a45a8ff | 1055 | USB_FlushTxFifo(hpcd->Instance, ep_addr & 0x7F); |
| bogdanm | 0:9b334a45a8ff | 1056 | } |
| bogdanm | 0:9b334a45a8ff | 1057 | else |
| bogdanm | 0:9b334a45a8ff | 1058 | { |
| bogdanm | 0:9b334a45a8ff | 1059 | USB_FlushRxFifo(hpcd->Instance); |
| bogdanm | 0:9b334a45a8ff | 1060 | } |
| bogdanm | 0:9b334a45a8ff | 1061 | |
| bogdanm | 0:9b334a45a8ff | 1062 | __HAL_UNLOCK(hpcd); |
| bogdanm | 0:9b334a45a8ff | 1063 | |
| bogdanm | 0:9b334a45a8ff | 1064 | return HAL_OK; |
| bogdanm | 0:9b334a45a8ff | 1065 | } |
| bogdanm | 0:9b334a45a8ff | 1066 | |
| bogdanm | 0:9b334a45a8ff | 1067 | /** |
| bogdanm | 0:9b334a45a8ff | 1068 | * @brief HAL_PCD_ActivateRemoteWakeup : active remote wakeup signalling |
| bogdanm | 0:9b334a45a8ff | 1069 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 1070 | * @retval HAL status |
| bogdanm | 0:9b334a45a8ff | 1071 | */ |
| bogdanm | 0:9b334a45a8ff | 1072 | HAL_StatusTypeDef HAL_PCD_ActivateRemoteWakeup(PCD_HandleTypeDef *hpcd) |
| bogdanm | 0:9b334a45a8ff | 1073 | { |
| bogdanm | 0:9b334a45a8ff | 1074 | return(USB_ActivateRemoteWakeup(hpcd->Instance)); |
| bogdanm | 0:9b334a45a8ff | 1075 | } |
| bogdanm | 0:9b334a45a8ff | 1076 | |
| bogdanm | 0:9b334a45a8ff | 1077 | /** |
| bogdanm | 0:9b334a45a8ff | 1078 | * @brief HAL_PCD_DeActivateRemoteWakeup : de-active remote wakeup signalling |
| bogdanm | 0:9b334a45a8ff | 1079 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 1080 | * @retval HAL status |
| bogdanm | 0:9b334a45a8ff | 1081 | */ |
| bogdanm | 0:9b334a45a8ff | 1082 | HAL_StatusTypeDef HAL_PCD_DeActivateRemoteWakeup(PCD_HandleTypeDef *hpcd) |
| bogdanm | 0:9b334a45a8ff | 1083 | { |
| bogdanm | 0:9b334a45a8ff | 1084 | return(USB_DeActivateRemoteWakeup(hpcd->Instance)); |
| bogdanm | 0:9b334a45a8ff | 1085 | } |
| bogdanm | 0:9b334a45a8ff | 1086 | /** |
| bogdanm | 0:9b334a45a8ff | 1087 | * @} |
| bogdanm | 0:9b334a45a8ff | 1088 | */ |
| bogdanm | 0:9b334a45a8ff | 1089 | |
| bogdanm | 0:9b334a45a8ff | 1090 | /** @defgroup PCD_Exported_Functions_Group4 Peripheral State functions |
| bogdanm | 0:9b334a45a8ff | 1091 | * @brief Peripheral State functions |
| bogdanm | 0:9b334a45a8ff | 1092 | * |
| bogdanm | 0:9b334a45a8ff | 1093 | @verbatim |
| bogdanm | 0:9b334a45a8ff | 1094 | =============================================================================== |
| bogdanm | 0:9b334a45a8ff | 1095 | ##### Peripheral State functions ##### |
| bogdanm | 0:9b334a45a8ff | 1096 | =============================================================================== |
| bogdanm | 0:9b334a45a8ff | 1097 | [..] |
| bogdanm | 0:9b334a45a8ff | 1098 | This subsection permits to get in run-time the status of the peripheral |
| bogdanm | 0:9b334a45a8ff | 1099 | and the data flow. |
| bogdanm | 0:9b334a45a8ff | 1100 | |
| bogdanm | 0:9b334a45a8ff | 1101 | @endverbatim |
| bogdanm | 0:9b334a45a8ff | 1102 | * @{ |
| bogdanm | 0:9b334a45a8ff | 1103 | */ |
| bogdanm | 0:9b334a45a8ff | 1104 | |
| bogdanm | 0:9b334a45a8ff | 1105 | /** |
| bogdanm | 0:9b334a45a8ff | 1106 | * @brief Return the PCD state |
| bogdanm | 0:9b334a45a8ff | 1107 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 1108 | * @retval HAL state |
| bogdanm | 0:9b334a45a8ff | 1109 | */ |
| bogdanm | 0:9b334a45a8ff | 1110 | PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd) |
| bogdanm | 0:9b334a45a8ff | 1111 | { |
| bogdanm | 0:9b334a45a8ff | 1112 | return hpcd->State; |
| bogdanm | 0:9b334a45a8ff | 1113 | } |
| bogdanm | 0:9b334a45a8ff | 1114 | |
| bogdanm | 0:9b334a45a8ff | 1115 | /** |
| bogdanm | 0:9b334a45a8ff | 1116 | * @} |
| bogdanm | 0:9b334a45a8ff | 1117 | */ |
| bogdanm | 0:9b334a45a8ff | 1118 | |
| bogdanm | 0:9b334a45a8ff | 1119 | /** |
| bogdanm | 0:9b334a45a8ff | 1120 | * @} |
| bogdanm | 0:9b334a45a8ff | 1121 | */ |
| bogdanm | 0:9b334a45a8ff | 1122 | |
| bogdanm | 0:9b334a45a8ff | 1123 | /** @addtogroup PCD_Private_Functions |
| bogdanm | 0:9b334a45a8ff | 1124 | * @{ |
| bogdanm | 0:9b334a45a8ff | 1125 | */ |
| bogdanm | 0:9b334a45a8ff | 1126 | #if defined (USB_OTG_FS) |
| bogdanm | 0:9b334a45a8ff | 1127 | /** |
| bogdanm | 0:9b334a45a8ff | 1128 | * @brief DCD_WriteEmptyTxFifo |
| bogdanm | 0:9b334a45a8ff | 1129 | * check FIFO for the next packet to be loaded |
| bogdanm | 0:9b334a45a8ff | 1130 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 1131 | * @param epnum : endpoint number |
| bogdanm | 0:9b334a45a8ff | 1132 | * This parameter can be a value from 0 to 15 |
| bogdanm | 0:9b334a45a8ff | 1133 | * @retval HAL status |
| bogdanm | 0:9b334a45a8ff | 1134 | */ |
| bogdanm | 0:9b334a45a8ff | 1135 | static HAL_StatusTypeDef PCD_WriteEmptyTxFifo(PCD_HandleTypeDef *hpcd, uint32_t epnum) |
| bogdanm | 0:9b334a45a8ff | 1136 | { |
| bogdanm | 0:9b334a45a8ff | 1137 | USB_OTG_GlobalTypeDef *USBx = hpcd->Instance; |
| bogdanm | 0:9b334a45a8ff | 1138 | USB_OTG_EPTypeDef *ep = NULL; |
| bogdanm | 0:9b334a45a8ff | 1139 | int32_t len = 0; |
| bogdanm | 0:9b334a45a8ff | 1140 | uint32_t len32b = 0; |
| bogdanm | 0:9b334a45a8ff | 1141 | uint32_t fifoemptymsk = 0; |
| bogdanm | 0:9b334a45a8ff | 1142 | |
| bogdanm | 0:9b334a45a8ff | 1143 | ep = &hpcd->IN_ep[epnum]; |
| bogdanm | 0:9b334a45a8ff | 1144 | len = ep->xfer_len - ep->xfer_count; |
| bogdanm | 0:9b334a45a8ff | 1145 | |
| bogdanm | 0:9b334a45a8ff | 1146 | if (len > ep->maxpacket) |
| bogdanm | 0:9b334a45a8ff | 1147 | { |
| bogdanm | 0:9b334a45a8ff | 1148 | len = ep->maxpacket; |
| bogdanm | 0:9b334a45a8ff | 1149 | } |
| bogdanm | 0:9b334a45a8ff | 1150 | |
| bogdanm | 0:9b334a45a8ff | 1151 | len32b = (len + 3) / 4; |
| bogdanm | 0:9b334a45a8ff | 1152 | |
| bogdanm | 0:9b334a45a8ff | 1153 | while ((USBx_INEP(epnum)->DTXFSTS & USB_OTG_DTXFSTS_INEPTFSAV) > len32b && |
| bogdanm | 0:9b334a45a8ff | 1154 | ep->xfer_count < ep->xfer_len && |
| bogdanm | 0:9b334a45a8ff | 1155 | ep->xfer_len != 0) |
| bogdanm | 0:9b334a45a8ff | 1156 | { |
| bogdanm | 0:9b334a45a8ff | 1157 | /* Write the FIFO */ |
| bogdanm | 0:9b334a45a8ff | 1158 | len = ep->xfer_len - ep->xfer_count; |
| bogdanm | 0:9b334a45a8ff | 1159 | |
| bogdanm | 0:9b334a45a8ff | 1160 | if (len > ep->maxpacket) |
| bogdanm | 0:9b334a45a8ff | 1161 | { |
| bogdanm | 0:9b334a45a8ff | 1162 | len = ep->maxpacket; |
| bogdanm | 0:9b334a45a8ff | 1163 | } |
| bogdanm | 0:9b334a45a8ff | 1164 | len32b = (len + 3) / 4; |
| bogdanm | 0:9b334a45a8ff | 1165 | |
| bogdanm | 0:9b334a45a8ff | 1166 | USB_WritePacket(USBx, ep->xfer_buff, epnum, len); |
| bogdanm | 0:9b334a45a8ff | 1167 | |
| bogdanm | 0:9b334a45a8ff | 1168 | ep->xfer_buff += len; |
| bogdanm | 0:9b334a45a8ff | 1169 | ep->xfer_count += len; |
| bogdanm | 0:9b334a45a8ff | 1170 | } |
| bogdanm | 0:9b334a45a8ff | 1171 | |
| bogdanm | 0:9b334a45a8ff | 1172 | if(len <= 0) |
| bogdanm | 0:9b334a45a8ff | 1173 | { |
| bogdanm | 0:9b334a45a8ff | 1174 | fifoemptymsk = 0x1 << epnum; |
| bogdanm | 0:9b334a45a8ff | 1175 | USBx_DEVICE->DIEPEMPMSK &= ~fifoemptymsk; |
| bogdanm | 0:9b334a45a8ff | 1176 | |
| bogdanm | 0:9b334a45a8ff | 1177 | } |
| bogdanm | 0:9b334a45a8ff | 1178 | |
| bogdanm | 0:9b334a45a8ff | 1179 | return HAL_OK; |
| bogdanm | 0:9b334a45a8ff | 1180 | } |
| bogdanm | 0:9b334a45a8ff | 1181 | #endif /* USB_OTG_FS */ |
| bogdanm | 0:9b334a45a8ff | 1182 | |
| bogdanm | 0:9b334a45a8ff | 1183 | #if defined (USB) |
| bogdanm | 0:9b334a45a8ff | 1184 | /** |
| bogdanm | 0:9b334a45a8ff | 1185 | * @brief This function handles PCD Endpoint interrupt request. |
| bogdanm | 0:9b334a45a8ff | 1186 | * @param hpcd: PCD handle |
| bogdanm | 0:9b334a45a8ff | 1187 | * @retval HAL status |
| bogdanm | 0:9b334a45a8ff | 1188 | */ |
| bogdanm | 0:9b334a45a8ff | 1189 | static HAL_StatusTypeDef PCD_EP_ISR_Handler(PCD_HandleTypeDef *hpcd) |
| bogdanm | 0:9b334a45a8ff | 1190 | { |
| bogdanm | 0:9b334a45a8ff | 1191 | PCD_EPTypeDef *ep = NULL; |
| bogdanm | 0:9b334a45a8ff | 1192 | uint16_t count = 0; |
| bogdanm | 0:9b334a45a8ff | 1193 | uint8_t epindex = 0; |
| bogdanm | 0:9b334a45a8ff | 1194 | __IO uint16_t wIstr = 0; |
| bogdanm | 0:9b334a45a8ff | 1195 | __IO uint16_t wEPVal = 0; |
| bogdanm | 0:9b334a45a8ff | 1196 | |
| bogdanm | 0:9b334a45a8ff | 1197 | /* stay in loop while pending interrupts */ |
| bogdanm | 0:9b334a45a8ff | 1198 | while (((wIstr = hpcd->Instance->ISTR) & USB_ISTR_CTR) != 0) |
| bogdanm | 0:9b334a45a8ff | 1199 | { |
| bogdanm | 0:9b334a45a8ff | 1200 | /* extract highest priority endpoint number */ |
| bogdanm | 0:9b334a45a8ff | 1201 | epindex = (uint8_t)(wIstr & USB_ISTR_EP_ID); |
| bogdanm | 0:9b334a45a8ff | 1202 | |
| bogdanm | 0:9b334a45a8ff | 1203 | if (epindex == 0) |
| bogdanm | 0:9b334a45a8ff | 1204 | { |
| bogdanm | 0:9b334a45a8ff | 1205 | /* Decode and service control endpoint interrupt */ |
| bogdanm | 0:9b334a45a8ff | 1206 | |
| bogdanm | 0:9b334a45a8ff | 1207 | /* DIR bit = origin of the interrupt */ |
| bogdanm | 0:9b334a45a8ff | 1208 | if ((wIstr & USB_ISTR_DIR) == 0) |
| bogdanm | 0:9b334a45a8ff | 1209 | { |
| bogdanm | 0:9b334a45a8ff | 1210 | /* DIR = 0 */ |
| bogdanm | 0:9b334a45a8ff | 1211 | |
| bogdanm | 0:9b334a45a8ff | 1212 | /* DIR = 0 => IN int */ |
| bogdanm | 0:9b334a45a8ff | 1213 | /* DIR = 0 implies that (EP_CTR_TX = 1) always */ |
| bogdanm | 0:9b334a45a8ff | 1214 | PCD_CLEAR_TX_EP_CTR(hpcd->Instance, PCD_ENDP0); |
| bogdanm | 0:9b334a45a8ff | 1215 | ep = &hpcd->IN_ep[0]; |
| bogdanm | 0:9b334a45a8ff | 1216 | |
| bogdanm | 0:9b334a45a8ff | 1217 | ep->xfer_count = PCD_GET_EP_TX_CNT(hpcd->Instance, ep->num); |
| bogdanm | 0:9b334a45a8ff | 1218 | ep->xfer_buff += ep->xfer_count; |
| bogdanm | 0:9b334a45a8ff | 1219 | |
| bogdanm | 0:9b334a45a8ff | 1220 | /* TX COMPLETE */ |
| bogdanm | 0:9b334a45a8ff | 1221 | HAL_PCD_DataInStageCallback(hpcd, 0); |
| bogdanm | 0:9b334a45a8ff | 1222 | |
| bogdanm | 0:9b334a45a8ff | 1223 | |
| bogdanm | 0:9b334a45a8ff | 1224 | if((hpcd->USB_Address > 0)&& ( ep->xfer_len == 0)) |
| bogdanm | 0:9b334a45a8ff | 1225 | { |
| bogdanm | 0:9b334a45a8ff | 1226 | hpcd->Instance->DADDR = (hpcd->USB_Address | USB_DADDR_EF); |
| bogdanm | 0:9b334a45a8ff | 1227 | hpcd->USB_Address = 0; |
| bogdanm | 0:9b334a45a8ff | 1228 | } |
| bogdanm | 0:9b334a45a8ff | 1229 | |
| bogdanm | 0:9b334a45a8ff | 1230 | } |
| bogdanm | 0:9b334a45a8ff | 1231 | else |
| bogdanm | 0:9b334a45a8ff | 1232 | { |
| bogdanm | 0:9b334a45a8ff | 1233 | /* DIR = 1 */ |
| bogdanm | 0:9b334a45a8ff | 1234 | |
| bogdanm | 0:9b334a45a8ff | 1235 | /* DIR = 1 & CTR_RX => SETUP or OUT int */ |
| bogdanm | 0:9b334a45a8ff | 1236 | /* DIR = 1 & (CTR_TX | CTR_RX) => 2 int pending */ |
| bogdanm | 0:9b334a45a8ff | 1237 | ep = &hpcd->OUT_ep[0]; |
| bogdanm | 0:9b334a45a8ff | 1238 | wEPVal = PCD_GET_ENDPOINT(hpcd->Instance, PCD_ENDP0); |
| bogdanm | 0:9b334a45a8ff | 1239 | |
| bogdanm | 0:9b334a45a8ff | 1240 | if ((wEPVal & USB_EP_SETUP) != 0) |
| bogdanm | 0:9b334a45a8ff | 1241 | { |
| bogdanm | 0:9b334a45a8ff | 1242 | /* Get SETUP Packet*/ |
| bogdanm | 0:9b334a45a8ff | 1243 | ep->xfer_count = PCD_GET_EP_RX_CNT(hpcd->Instance, ep->num); |
| bogdanm | 0:9b334a45a8ff | 1244 | USB_ReadPMA(hpcd->Instance, (uint8_t*)hpcd->Setup ,ep->pmaadress , ep->xfer_count); |
| bogdanm | 0:9b334a45a8ff | 1245 | /* SETUP bit kept frozen while CTR_RX = 1*/ |
| bogdanm | 0:9b334a45a8ff | 1246 | PCD_CLEAR_RX_EP_CTR(hpcd->Instance, PCD_ENDP0); |
| bogdanm | 0:9b334a45a8ff | 1247 | |
| bogdanm | 0:9b334a45a8ff | 1248 | /* Process SETUP Packet*/ |
| bogdanm | 0:9b334a45a8ff | 1249 | HAL_PCD_SetupStageCallback(hpcd); |
| bogdanm | 0:9b334a45a8ff | 1250 | } |
| bogdanm | 0:9b334a45a8ff | 1251 | |
| bogdanm | 0:9b334a45a8ff | 1252 | else if ((wEPVal & USB_EP_CTR_RX) != 0) |
| bogdanm | 0:9b334a45a8ff | 1253 | { |
| bogdanm | 0:9b334a45a8ff | 1254 | PCD_CLEAR_RX_EP_CTR(hpcd->Instance, PCD_ENDP0); |
| bogdanm | 0:9b334a45a8ff | 1255 | /* Get Control Data OUT Packet*/ |
| bogdanm | 0:9b334a45a8ff | 1256 | ep->xfer_count = PCD_GET_EP_RX_CNT(hpcd->Instance, ep->num); |
| bogdanm | 0:9b334a45a8ff | 1257 | |
| bogdanm | 0:9b334a45a8ff | 1258 | if (ep->xfer_count != 0) |
| bogdanm | 0:9b334a45a8ff | 1259 | { |
| bogdanm | 0:9b334a45a8ff | 1260 | USB_ReadPMA(hpcd->Instance, ep->xfer_buff, ep->pmaadress, ep->xfer_count); |
| bogdanm | 0:9b334a45a8ff | 1261 | ep->xfer_buff+=ep->xfer_count; |
| bogdanm | 0:9b334a45a8ff | 1262 | } |
| bogdanm | 0:9b334a45a8ff | 1263 | |
| bogdanm | 0:9b334a45a8ff | 1264 | /* Process Control Data OUT Packet*/ |
| bogdanm | 0:9b334a45a8ff | 1265 | HAL_PCD_DataOutStageCallback(hpcd, 0); |
| bogdanm | 0:9b334a45a8ff | 1266 | |
| bogdanm | 0:9b334a45a8ff | 1267 | PCD_SET_EP_RX_CNT(hpcd->Instance, PCD_ENDP0, ep->maxpacket); |
| bogdanm | 0:9b334a45a8ff | 1268 | PCD_SET_EP_RX_STATUS(hpcd->Instance, PCD_ENDP0, USB_EP_RX_VALID); |
| bogdanm | 0:9b334a45a8ff | 1269 | } |
| bogdanm | 0:9b334a45a8ff | 1270 | } |
| bogdanm | 0:9b334a45a8ff | 1271 | } |
| bogdanm | 0:9b334a45a8ff | 1272 | else |
| bogdanm | 0:9b334a45a8ff | 1273 | { |
| bogdanm | 0:9b334a45a8ff | 1274 | /* Decode and service non control endpoints interrupt */ |
| bogdanm | 0:9b334a45a8ff | 1275 | |
| bogdanm | 0:9b334a45a8ff | 1276 | /* process related endpoint register */ |
| bogdanm | 0:9b334a45a8ff | 1277 | wEPVal = PCD_GET_ENDPOINT(hpcd->Instance, epindex); |
| bogdanm | 0:9b334a45a8ff | 1278 | if ((wEPVal & USB_EP_CTR_RX) != 0) |
| bogdanm | 0:9b334a45a8ff | 1279 | { |
| bogdanm | 0:9b334a45a8ff | 1280 | /* clear int flag */ |
| bogdanm | 0:9b334a45a8ff | 1281 | PCD_CLEAR_RX_EP_CTR(hpcd->Instance, epindex); |
| bogdanm | 0:9b334a45a8ff | 1282 | ep = &hpcd->OUT_ep[epindex]; |
| bogdanm | 0:9b334a45a8ff | 1283 | |
| bogdanm | 0:9b334a45a8ff | 1284 | /* OUT double Buffering*/ |
| bogdanm | 0:9b334a45a8ff | 1285 | if (ep->doublebuffer == 0) |
| bogdanm | 0:9b334a45a8ff | 1286 | { |
| bogdanm | 0:9b334a45a8ff | 1287 | count = PCD_GET_EP_RX_CNT(hpcd->Instance, ep->num); |
| bogdanm | 0:9b334a45a8ff | 1288 | if (count != 0) |
| bogdanm | 0:9b334a45a8ff | 1289 | { |
| bogdanm | 0:9b334a45a8ff | 1290 | USB_ReadPMA(hpcd->Instance, ep->xfer_buff, ep->pmaadress, count); |
| bogdanm | 0:9b334a45a8ff | 1291 | } |
| bogdanm | 0:9b334a45a8ff | 1292 | } |
| bogdanm | 0:9b334a45a8ff | 1293 | else |
| bogdanm | 0:9b334a45a8ff | 1294 | { |
| bogdanm | 0:9b334a45a8ff | 1295 | if (PCD_GET_ENDPOINT(hpcd->Instance, ep->num) & USB_EP_DTOG_RX) |
| bogdanm | 0:9b334a45a8ff | 1296 | { |
| bogdanm | 0:9b334a45a8ff | 1297 | /*read from endpoint BUF0Addr buffer*/ |
| bogdanm | 0:9b334a45a8ff | 1298 | count = PCD_GET_EP_DBUF0_CNT(hpcd->Instance, ep->num); |
| bogdanm | 0:9b334a45a8ff | 1299 | if (count != 0) |
| bogdanm | 0:9b334a45a8ff | 1300 | { |
| bogdanm | 0:9b334a45a8ff | 1301 | USB_ReadPMA(hpcd->Instance, ep->xfer_buff, ep->pmaaddr0, count); |
| bogdanm | 0:9b334a45a8ff | 1302 | } |
| bogdanm | 0:9b334a45a8ff | 1303 | } |
| bogdanm | 0:9b334a45a8ff | 1304 | else |
| bogdanm | 0:9b334a45a8ff | 1305 | { |
| bogdanm | 0:9b334a45a8ff | 1306 | /*read from endpoint BUF1Addr buffer*/ |
| bogdanm | 0:9b334a45a8ff | 1307 | count = PCD_GET_EP_DBUF1_CNT(hpcd->Instance, ep->num); |
| bogdanm | 0:9b334a45a8ff | 1308 | if (count != 0) |
| bogdanm | 0:9b334a45a8ff | 1309 | { |
| bogdanm | 0:9b334a45a8ff | 1310 | USB_ReadPMA(hpcd->Instance, ep->xfer_buff, ep->pmaaddr1, count); |
| bogdanm | 0:9b334a45a8ff | 1311 | } |
| bogdanm | 0:9b334a45a8ff | 1312 | } |
| bogdanm | 0:9b334a45a8ff | 1313 | PCD_FreeUserBuffer(hpcd->Instance, ep->num, PCD_EP_DBUF_OUT); |
| bogdanm | 0:9b334a45a8ff | 1314 | } |
| bogdanm | 0:9b334a45a8ff | 1315 | /*multi-packet on the NON control OUT endpoint*/ |
| bogdanm | 0:9b334a45a8ff | 1316 | ep->xfer_count+=count; |
| bogdanm | 0:9b334a45a8ff | 1317 | ep->xfer_buff+=count; |
| bogdanm | 0:9b334a45a8ff | 1318 | |
| bogdanm | 0:9b334a45a8ff | 1319 | if ((ep->xfer_len == 0) || (count < ep->maxpacket)) |
| bogdanm | 0:9b334a45a8ff | 1320 | { |
| bogdanm | 0:9b334a45a8ff | 1321 | /* RX COMPLETE */ |
| bogdanm | 0:9b334a45a8ff | 1322 | HAL_PCD_DataOutStageCallback(hpcd, ep->num); |
| bogdanm | 0:9b334a45a8ff | 1323 | } |
| bogdanm | 0:9b334a45a8ff | 1324 | else |
| bogdanm | 0:9b334a45a8ff | 1325 | { |
| bogdanm | 0:9b334a45a8ff | 1326 | HAL_PCD_EP_Receive(hpcd, ep->num, ep->xfer_buff, ep->xfer_len); |
| bogdanm | 0:9b334a45a8ff | 1327 | } |
| bogdanm | 0:9b334a45a8ff | 1328 | |
| bogdanm | 0:9b334a45a8ff | 1329 | } /* if((wEPVal & EP_CTR_RX) */ |
| bogdanm | 0:9b334a45a8ff | 1330 | |
| bogdanm | 0:9b334a45a8ff | 1331 | if ((wEPVal & USB_EP_CTR_TX) != 0) |
| bogdanm | 0:9b334a45a8ff | 1332 | { |
| bogdanm | 0:9b334a45a8ff | 1333 | ep = &hpcd->IN_ep[epindex]; |
| bogdanm | 0:9b334a45a8ff | 1334 | |
| bogdanm | 0:9b334a45a8ff | 1335 | /* clear int flag */ |
| bogdanm | 0:9b334a45a8ff | 1336 | PCD_CLEAR_TX_EP_CTR(hpcd->Instance, epindex); |
| bogdanm | 0:9b334a45a8ff | 1337 | |
| bogdanm | 0:9b334a45a8ff | 1338 | /* IN double Buffering*/ |
| bogdanm | 0:9b334a45a8ff | 1339 | if (ep->doublebuffer == 0) |
| bogdanm | 0:9b334a45a8ff | 1340 | { |
| bogdanm | 0:9b334a45a8ff | 1341 | ep->xfer_count = PCD_GET_EP_TX_CNT(hpcd->Instance, ep->num); |
| bogdanm | 0:9b334a45a8ff | 1342 | if (ep->xfer_count != 0) |
| bogdanm | 0:9b334a45a8ff | 1343 | { |
| bogdanm | 0:9b334a45a8ff | 1344 | USB_WritePMA(hpcd->Instance, ep->xfer_buff, ep->pmaadress, ep->xfer_count); |
| bogdanm | 0:9b334a45a8ff | 1345 | } |
| bogdanm | 0:9b334a45a8ff | 1346 | } |
| bogdanm | 0:9b334a45a8ff | 1347 | else |
| bogdanm | 0:9b334a45a8ff | 1348 | { |
| bogdanm | 0:9b334a45a8ff | 1349 | if (PCD_GET_ENDPOINT(hpcd->Instance, ep->num) & USB_EP_DTOG_TX) |
| bogdanm | 0:9b334a45a8ff | 1350 | { |
| bogdanm | 0:9b334a45a8ff | 1351 | /*read from endpoint BUF0Addr buffer*/ |
| bogdanm | 0:9b334a45a8ff | 1352 | ep->xfer_count = PCD_GET_EP_DBUF0_CNT(hpcd->Instance, ep->num); |
| bogdanm | 0:9b334a45a8ff | 1353 | if (ep->xfer_count != 0) |
| bogdanm | 0:9b334a45a8ff | 1354 | { |
| bogdanm | 0:9b334a45a8ff | 1355 | USB_WritePMA(hpcd->Instance, ep->xfer_buff, ep->pmaaddr0, ep->xfer_count); |
| bogdanm | 0:9b334a45a8ff | 1356 | } |
| bogdanm | 0:9b334a45a8ff | 1357 | } |
| bogdanm | 0:9b334a45a8ff | 1358 | else |
| bogdanm | 0:9b334a45a8ff | 1359 | { |
| bogdanm | 0:9b334a45a8ff | 1360 | /*read from endpoint BUF1Addr buffer*/ |
| bogdanm | 0:9b334a45a8ff | 1361 | ep->xfer_count = PCD_GET_EP_DBUF1_CNT(hpcd->Instance, ep->num); |
| bogdanm | 0:9b334a45a8ff | 1362 | if (ep->xfer_count != 0) |
| bogdanm | 0:9b334a45a8ff | 1363 | { |
| bogdanm | 0:9b334a45a8ff | 1364 | USB_WritePMA(hpcd->Instance, ep->xfer_buff, ep->pmaaddr1, ep->xfer_count); |
| bogdanm | 0:9b334a45a8ff | 1365 | } |
| bogdanm | 0:9b334a45a8ff | 1366 | } |
| bogdanm | 0:9b334a45a8ff | 1367 | PCD_FreeUserBuffer(hpcd->Instance, ep->num, PCD_EP_DBUF_IN); |
| bogdanm | 0:9b334a45a8ff | 1368 | } |
| bogdanm | 0:9b334a45a8ff | 1369 | /*multi-packet on the NON control IN endpoint*/ |
| bogdanm | 0:9b334a45a8ff | 1370 | ep->xfer_count = PCD_GET_EP_TX_CNT(hpcd->Instance, ep->num); |
| bogdanm | 0:9b334a45a8ff | 1371 | ep->xfer_buff+=ep->xfer_count; |
| bogdanm | 0:9b334a45a8ff | 1372 | |
| bogdanm | 0:9b334a45a8ff | 1373 | /* Zero Length Packet? */ |
| bogdanm | 0:9b334a45a8ff | 1374 | if (ep->xfer_len == 0) |
| bogdanm | 0:9b334a45a8ff | 1375 | { |
| bogdanm | 0:9b334a45a8ff | 1376 | /* TX COMPLETE */ |
| bogdanm | 0:9b334a45a8ff | 1377 | HAL_PCD_DataInStageCallback(hpcd, ep->num); |
| bogdanm | 0:9b334a45a8ff | 1378 | } |
| bogdanm | 0:9b334a45a8ff | 1379 | else |
| bogdanm | 0:9b334a45a8ff | 1380 | { |
| bogdanm | 0:9b334a45a8ff | 1381 | HAL_PCD_EP_Transmit(hpcd, ep->num, ep->xfer_buff, ep->xfer_len); |
| bogdanm | 0:9b334a45a8ff | 1382 | } |
| bogdanm | 0:9b334a45a8ff | 1383 | } |
| bogdanm | 0:9b334a45a8ff | 1384 | } |
| bogdanm | 0:9b334a45a8ff | 1385 | } |
| bogdanm | 0:9b334a45a8ff | 1386 | return HAL_OK; |
| bogdanm | 0:9b334a45a8ff | 1387 | } |
| bogdanm | 0:9b334a45a8ff | 1388 | #endif /* USB */ |
| bogdanm | 0:9b334a45a8ff | 1389 | |
| bogdanm | 0:9b334a45a8ff | 1390 | /** |
| bogdanm | 0:9b334a45a8ff | 1391 | * @} |
| bogdanm | 0:9b334a45a8ff | 1392 | */ |
| bogdanm | 0:9b334a45a8ff | 1393 | |
| bogdanm | 0:9b334a45a8ff | 1394 | /** |
| bogdanm | 0:9b334a45a8ff | 1395 | * @} |
| bogdanm | 0:9b334a45a8ff | 1396 | */ |
| bogdanm | 0:9b334a45a8ff | 1397 | |
| bogdanm | 0:9b334a45a8ff | 1398 | #endif /* STM32F102x6 || STM32F102xB || */ |
| bogdanm | 0:9b334a45a8ff | 1399 | /* STM32F103x6 || STM32F103xB || */ |
| bogdanm | 0:9b334a45a8ff | 1400 | /* STM32F103xE || STM32F103xG || */ |
| bogdanm | 0:9b334a45a8ff | 1401 | /* STM32F105xC || STM32F107xC */ |
| bogdanm | 0:9b334a45a8ff | 1402 | |
| bogdanm | 0:9b334a45a8ff | 1403 | #endif /* HAL_PCD_MODULE_ENABLED */ |
| bogdanm | 0:9b334a45a8ff | 1404 | |
| bogdanm | 0:9b334a45a8ff | 1405 | |
| bogdanm | 0:9b334a45a8ff | 1406 | /** |
| bogdanm | 0:9b334a45a8ff | 1407 | * @} |
| bogdanm | 0:9b334a45a8ff | 1408 | */ |
| bogdanm | 0:9b334a45a8ff | 1409 | |
| bogdanm | 0:9b334a45a8ff | 1410 | /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ |
