mbed official / mbed

Dependents:   hello SerialTestv11 SerialTestv12 Sierpinski ... more

Committer:
Kojto
Date:
Thu Jul 07 14:34:11 2016 +0100
Revision:
122:f9eeca106725
Parent:
93:e188a91d3eaa
Child:
123:b0220dba8be7
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 93:e188a91d3eaa 1 /**
Kojto 93:e188a91d3eaa 2 ******************************************************************************
Kojto 93:e188a91d3eaa 3 * @file stm32f3xx_hal_dma_ex.h
Kojto 93:e188a91d3eaa 4 * @author MCD Application Team
Kojto 122:f9eeca106725 5 * @version V1.2.1
Kojto 122:f9eeca106725 6 * @date 29-April-2015
Kojto 122:f9eeca106725 7 * @brief Header file of DMA HAL extension module.
Kojto 93:e188a91d3eaa 8 ******************************************************************************
Kojto 93:e188a91d3eaa 9 * @attention
Kojto 93:e188a91d3eaa 10 *
Kojto 122:f9eeca106725 11 * <h2><center>&copy; COPYRIGHT(c) 2016 STMicroelectronics</center></h2>
Kojto 93:e188a91d3eaa 12 *
Kojto 93:e188a91d3eaa 13 * Redistribution and use in source and binary forms, with or without modification,
Kojto 93:e188a91d3eaa 14 * are permitted provided that the following conditions are met:
Kojto 93:e188a91d3eaa 15 * 1. Redistributions of source code must retain the above copyright notice,
Kojto 93:e188a91d3eaa 16 * this list of conditions and the following disclaimer.
Kojto 93:e188a91d3eaa 17 * 2. Redistributions in binary form must reproduce the above copyright notice,
Kojto 93:e188a91d3eaa 18 * this list of conditions and the following disclaimer in the documentation
Kojto 93:e188a91d3eaa 19 * and/or other materials provided with the distribution.
Kojto 93:e188a91d3eaa 20 * 3. Neither the name of STMicroelectronics nor the names of its contributors
Kojto 93:e188a91d3eaa 21 * may be used to endorse or promote products derived from this software
Kojto 93:e188a91d3eaa 22 * without specific prior written permission.
Kojto 93:e188a91d3eaa 23 *
Kojto 93:e188a91d3eaa 24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
Kojto 93:e188a91d3eaa 25 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
Kojto 93:e188a91d3eaa 26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
Kojto 93:e188a91d3eaa 27 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
Kojto 93:e188a91d3eaa 28 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
Kojto 93:e188a91d3eaa 29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
Kojto 93:e188a91d3eaa 30 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
Kojto 93:e188a91d3eaa 31 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
Kojto 93:e188a91d3eaa 32 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
Kojto 93:e188a91d3eaa 33 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Kojto 93:e188a91d3eaa 34 *
Kojto 93:e188a91d3eaa 35 ******************************************************************************
Kojto 93:e188a91d3eaa 36 */
Kojto 93:e188a91d3eaa 37
Kojto 93:e188a91d3eaa 38 /* Define to prevent recursive inclusion -------------------------------------*/
Kojto 93:e188a91d3eaa 39 #ifndef __STM32F3xx_HAL_DMA_EX_H
Kojto 93:e188a91d3eaa 40 #define __STM32F3xx_HAL_DMA_EX_H
Kojto 93:e188a91d3eaa 41
Kojto 93:e188a91d3eaa 42 #ifdef __cplusplus
Kojto 93:e188a91d3eaa 43 extern "C" {
Kojto 93:e188a91d3eaa 44 #endif
Kojto 93:e188a91d3eaa 45
Kojto 93:e188a91d3eaa 46 /* Includes ------------------------------------------------------------------*/
Kojto 93:e188a91d3eaa 47 #include "stm32f3xx_hal_def.h"
Kojto 93:e188a91d3eaa 48
Kojto 93:e188a91d3eaa 49 /** @addtogroup STM32F3xx_HAL_Driver
Kojto 93:e188a91d3eaa 50 * @{
Kojto 93:e188a91d3eaa 51 */
Kojto 93:e188a91d3eaa 52
Kojto 122:f9eeca106725 53 /** @addtogroup DMAEx
Kojto 93:e188a91d3eaa 54 * @{
Kojto 93:e188a91d3eaa 55 */
Kojto 93:e188a91d3eaa 56
Kojto 93:e188a91d3eaa 57 /* Exported types ------------------------------------------------------------*/
Kojto 93:e188a91d3eaa 58 /* Exported constants --------------------------------------------------------*/
Kojto 122:f9eeca106725 59 /* Exported macro ------------------------------------------------------------*/
Kojto 93:e188a91d3eaa 60 /** @defgroup DMAEx_Exported_Macros DMA Extended Exported Macros
Kojto 93:e188a91d3eaa 61 * @{
Kojto 93:e188a91d3eaa 62 */
Kojto 93:e188a91d3eaa 63 /* Interrupt & Flag management */
Kojto 93:e188a91d3eaa 64
Kojto 122:f9eeca106725 65 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx) || \
Kojto 122:f9eeca106725 66 defined(STM32F302xC) || defined(STM32F303xC) || defined(STM32F358xx) || \
Kojto 122:f9eeca106725 67 defined(STM32F373xC) || defined(STM32F378xx)
Kojto 93:e188a91d3eaa 68 /**
Kojto 93:e188a91d3eaa 69 * @brief Returns the current DMA Channel transfer complete flag.
Kojto 93:e188a91d3eaa 70 * @param __HANDLE__: DMA handle
Kojto 93:e188a91d3eaa 71 * @retval The specified transfer complete flag index.
Kojto 93:e188a91d3eaa 72 */
Kojto 93:e188a91d3eaa 73 #define __HAL_DMA_GET_TC_FLAG_INDEX(__HANDLE__) \
Kojto 93:e188a91d3eaa 74 (((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_TC1 :\
Kojto 93:e188a91d3eaa 75 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_TC2 :\
Kojto 93:e188a91d3eaa 76 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_TC3 :\
Kojto 93:e188a91d3eaa 77 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_TC4 :\
Kojto 93:e188a91d3eaa 78 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_TC5 :\
Kojto 93:e188a91d3eaa 79 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_TC6 :\
Kojto 93:e188a91d3eaa 80 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel7))? DMA_FLAG_TC7 :\
Kojto 93:e188a91d3eaa 81 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel1))? DMA_FLAG_TC1 :\
Kojto 93:e188a91d3eaa 82 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel2))? DMA_FLAG_TC2 :\
Kojto 93:e188a91d3eaa 83 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel3))? DMA_FLAG_TC3 :\
Kojto 93:e188a91d3eaa 84 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel4))? DMA_FLAG_TC4 :\
Kojto 93:e188a91d3eaa 85 DMA_FLAG_TC5)
Kojto 93:e188a91d3eaa 86
Kojto 93:e188a91d3eaa 87 /**
Kojto 93:e188a91d3eaa 88 * @brief Returns the current DMA Channel half transfer complete flag.
Kojto 93:e188a91d3eaa 89 * @param __HANDLE__: DMA handle
Kojto 93:e188a91d3eaa 90 * @retval The specified half transfer complete flag index.
Kojto 93:e188a91d3eaa 91 */
Kojto 93:e188a91d3eaa 92 #define __HAL_DMA_GET_HT_FLAG_INDEX(__HANDLE__)\
Kojto 93:e188a91d3eaa 93 (((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_HT1 :\
Kojto 93:e188a91d3eaa 94 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_HT2 :\
Kojto 93:e188a91d3eaa 95 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_HT3 :\
Kojto 93:e188a91d3eaa 96 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_HT4 :\
Kojto 93:e188a91d3eaa 97 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_HT5 :\
Kojto 93:e188a91d3eaa 98 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_HT6 :\
Kojto 93:e188a91d3eaa 99 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel7))? DMA_FLAG_HT7 :\
Kojto 93:e188a91d3eaa 100 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel1))? DMA_FLAG_HT1 :\
Kojto 93:e188a91d3eaa 101 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel2))? DMA_FLAG_HT2 :\
Kojto 93:e188a91d3eaa 102 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel3))? DMA_FLAG_HT3 :\
Kojto 93:e188a91d3eaa 103 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel4))? DMA_FLAG_HT4 :\
Kojto 93:e188a91d3eaa 104 DMA_FLAG_HT5)
Kojto 93:e188a91d3eaa 105
Kojto 93:e188a91d3eaa 106 /**
Kojto 93:e188a91d3eaa 107 * @brief Returns the current DMA Channel transfer error flag.
Kojto 93:e188a91d3eaa 108 * @param __HANDLE__: DMA handle
Kojto 93:e188a91d3eaa 109 * @retval The specified transfer error flag index.
Kojto 93:e188a91d3eaa 110 */
Kojto 93:e188a91d3eaa 111 #define __HAL_DMA_GET_TE_FLAG_INDEX(__HANDLE__)\
Kojto 93:e188a91d3eaa 112 (((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_TE1 :\
Kojto 93:e188a91d3eaa 113 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_TE2 :\
Kojto 93:e188a91d3eaa 114 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_TE3 :\
Kojto 93:e188a91d3eaa 115 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_TE4 :\
Kojto 93:e188a91d3eaa 116 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_TE5 :\
Kojto 93:e188a91d3eaa 117 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_TE6 :\
Kojto 93:e188a91d3eaa 118 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel7))? DMA_FLAG_TE7 :\
Kojto 93:e188a91d3eaa 119 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel1))? DMA_FLAG_TE1 :\
Kojto 93:e188a91d3eaa 120 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel2))? DMA_FLAG_TE2 :\
Kojto 93:e188a91d3eaa 121 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel3))? DMA_FLAG_TE3 :\
Kojto 93:e188a91d3eaa 122 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel4))? DMA_FLAG_TE4 :\
Kojto 93:e188a91d3eaa 123 DMA_FLAG_TE5)
Kojto 93:e188a91d3eaa 124
Kojto 93:e188a91d3eaa 125 /**
Kojto 122:f9eeca106725 126 * @brief Return the current DMA Channel Global interrupt flag.
Kojto 122:f9eeca106725 127 * @param __HANDLE__: DMA handle
Kojto 122:f9eeca106725 128 * @retval The specified transfer error flag index.
Kojto 122:f9eeca106725 129 */
Kojto 122:f9eeca106725 130 #define __HAL_DMA_GET_GI_FLAG_INDEX(__HANDLE__)\
Kojto 122:f9eeca106725 131 (((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_GL1 :\
Kojto 122:f9eeca106725 132 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_GL2 :\
Kojto 122:f9eeca106725 133 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_GL3 :\
Kojto 122:f9eeca106725 134 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_GL4 :\
Kojto 122:f9eeca106725 135 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_GL5 :\
Kojto 122:f9eeca106725 136 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_GL6 :\
Kojto 122:f9eeca106725 137 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel7))? DMA_FLAG_GL7 :\
Kojto 122:f9eeca106725 138 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel1))? DMA_FLAG_GL1 :\
Kojto 122:f9eeca106725 139 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel2))? DMA_FLAG_GL2 :\
Kojto 122:f9eeca106725 140 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel3))? DMA_FLAG_GL3 :\
Kojto 122:f9eeca106725 141 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel4))? DMA_FLAG_GL4 :\
Kojto 122:f9eeca106725 142 DMA_FLAG_GL5)
Kojto 122:f9eeca106725 143
Kojto 122:f9eeca106725 144 /**
Kojto 93:e188a91d3eaa 145 * @brief Get the DMA Channel pending flags.
Kojto 93:e188a91d3eaa 146 * @param __HANDLE__: DMA handle
Kojto 93:e188a91d3eaa 147 * @param __FLAG__: Get the specified flag.
Kojto 93:e188a91d3eaa 148 * This parameter can be any combination of the following values:
Kojto 93:e188a91d3eaa 149 * @arg DMA_FLAG_TCx: Transfer complete flag
Kojto 93:e188a91d3eaa 150 * @arg DMA_FLAG_HTx: Half transfer complete flag
Kojto 93:e188a91d3eaa 151 * @arg DMA_FLAG_TEx: Transfer error flag
Kojto 122:f9eeca106725 152 * Where x can be 1_7 or 1_5 (depending on DMA1 or DMA2) to select the DMA Channel flag.
Kojto 93:e188a91d3eaa 153 * @retval The state of FLAG (SET or RESET).
Kojto 93:e188a91d3eaa 154 */
Kojto 93:e188a91d3eaa 155 #define __HAL_DMA_GET_FLAG(__HANDLE__, __FLAG__)\
Kojto 93:e188a91d3eaa 156 (((uint32_t)((__HANDLE__)->Instance) > (uint32_t)DMA1_Channel7)? (DMA2->ISR & (__FLAG__)) :\
Kojto 93:e188a91d3eaa 157 (DMA1->ISR & (__FLAG__)))
Kojto 93:e188a91d3eaa 158
Kojto 93:e188a91d3eaa 159 /**
Kojto 93:e188a91d3eaa 160 * @brief Clears the DMA Channel pending flags.
Kojto 93:e188a91d3eaa 161 * @param __HANDLE__: DMA handle
Kojto 93:e188a91d3eaa 162 * @param __FLAG__: specifies the flag to clear.
Kojto 93:e188a91d3eaa 163 * This parameter can be any combination of the following values:
Kojto 93:e188a91d3eaa 164 * @arg DMA_FLAG_TCx: Transfer complete flag
Kojto 93:e188a91d3eaa 165 * @arg DMA_FLAG_HTx: Half transfer complete flag
Kojto 93:e188a91d3eaa 166 * @arg DMA_FLAG_TEx: Transfer error flag
Kojto 122:f9eeca106725 167 * Where x can be 1_7 or 1_5 (depending on DMA1 or DMA2) to select the DMA Channel flag.
Kojto 93:e188a91d3eaa 168 * @retval None
Kojto 93:e188a91d3eaa 169 */
Kojto 93:e188a91d3eaa 170 #define __HAL_DMA_CLEAR_FLAG(__HANDLE__, __FLAG__) \
Kojto 93:e188a91d3eaa 171 (((uint32_t)((__HANDLE__)->Instance) > (uint32_t)DMA1_Channel7)? (DMA2->IFCR = (__FLAG__)) :\
Kojto 93:e188a91d3eaa 172 (DMA1->IFCR = (__FLAG__)))
Kojto 93:e188a91d3eaa 173
Kojto 93:e188a91d3eaa 174 /**
Kojto 93:e188a91d3eaa 175 * @}
Kojto 93:e188a91d3eaa 176 */
Kojto 93:e188a91d3eaa 177
Kojto 122:f9eeca106725 178 #else /* STM32F301x8_STM32F302x8_STM32F318xx_STM32F303x8_STM32F334x8_STM32F328xx Product devices */
Kojto 122:f9eeca106725 179 /** @defgroup DMA_Low_density_Medium_density_Product_devices DMA Low density and Medium density product devices
Kojto 122:f9eeca106725 180 * @{
Kojto 122:f9eeca106725 181 */
Kojto 93:e188a91d3eaa 182
Kojto 122:f9eeca106725 183 /**
Kojto 122:f9eeca106725 184 * @brief Returns the current DMA Channel transfer complete flag.
Kojto 122:f9eeca106725 185 * @param __HANDLE__: DMA handle
Kojto 122:f9eeca106725 186 * @retval The specified transfer complete flag index.
Kojto 93:e188a91d3eaa 187 */
Kojto 93:e188a91d3eaa 188 #define __HAL_DMA_GET_TC_FLAG_INDEX(__HANDLE__) \
Kojto 93:e188a91d3eaa 189 (((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_TC1 :\
Kojto 93:e188a91d3eaa 190 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_TC2 :\
Kojto 93:e188a91d3eaa 191 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_TC3 :\
Kojto 93:e188a91d3eaa 192 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_TC4 :\
Kojto 93:e188a91d3eaa 193 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_TC5 :\
Kojto 93:e188a91d3eaa 194 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_TC6 :\
Kojto 93:e188a91d3eaa 195 DMA_FLAG_TC7)
Kojto 93:e188a91d3eaa 196
Kojto 93:e188a91d3eaa 197 /**
Kojto 93:e188a91d3eaa 198 * @brief Returns the current DMA Channel half transfer complete flag.
Kojto 93:e188a91d3eaa 199 * @param __HANDLE__: DMA handle
Kojto 93:e188a91d3eaa 200 * @retval The specified half transfer complete flag index.
Kojto 93:e188a91d3eaa 201 */
Kojto 93:e188a91d3eaa 202 #define __HAL_DMA_GET_HT_FLAG_INDEX(__HANDLE__)\
Kojto 93:e188a91d3eaa 203 (((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_HT1 :\
Kojto 93:e188a91d3eaa 204 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_HT2 :\
Kojto 93:e188a91d3eaa 205 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_HT3 :\
Kojto 93:e188a91d3eaa 206 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_HT4 :\
Kojto 93:e188a91d3eaa 207 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_HT5 :\
Kojto 93:e188a91d3eaa 208 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_HT6 :\
Kojto 93:e188a91d3eaa 209 DMA_FLAG_HT7)
Kojto 93:e188a91d3eaa 210
Kojto 93:e188a91d3eaa 211 /**
Kojto 93:e188a91d3eaa 212 * @brief Returns the current DMA Channel transfer error flag.
Kojto 93:e188a91d3eaa 213 * @param __HANDLE__: DMA handle
Kojto 93:e188a91d3eaa 214 * @retval The specified transfer error flag index.
Kojto 93:e188a91d3eaa 215 */
Kojto 93:e188a91d3eaa 216 #define __HAL_DMA_GET_TE_FLAG_INDEX(__HANDLE__)\
Kojto 93:e188a91d3eaa 217 (((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_TE1 :\
Kojto 93:e188a91d3eaa 218 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_TE2 :\
Kojto 93:e188a91d3eaa 219 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_TE3 :\
Kojto 93:e188a91d3eaa 220 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_TE4 :\
Kojto 93:e188a91d3eaa 221 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_TE5 :\
Kojto 93:e188a91d3eaa 222 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_TE6 :\
Kojto 93:e188a91d3eaa 223 DMA_FLAG_TE7)
Kojto 93:e188a91d3eaa 224
Kojto 93:e188a91d3eaa 225 /**
Kojto 122:f9eeca106725 226 * @brief Return the current DMA Channel Global interrupt flag.
Kojto 122:f9eeca106725 227 * @param __HANDLE__: DMA handle
Kojto 122:f9eeca106725 228 * @retval The specified transfer error flag index.
Kojto 122:f9eeca106725 229 */
Kojto 122:f9eeca106725 230 #define __HAL_DMA_GET_GI_FLAG_INDEX(__HANDLE__)\
Kojto 122:f9eeca106725 231 (((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_GL1 :\
Kojto 122:f9eeca106725 232 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_GL2 :\
Kojto 122:f9eeca106725 233 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_GL3 :\
Kojto 122:f9eeca106725 234 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_GL4 :\
Kojto 122:f9eeca106725 235 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_GL5 :\
Kojto 122:f9eeca106725 236 ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_GL6 :\
Kojto 122:f9eeca106725 237 DMA_FLAG_GL7)
Kojto 122:f9eeca106725 238
Kojto 122:f9eeca106725 239 /**
Kojto 93:e188a91d3eaa 240 * @brief Get the DMA Channel pending flags.
Kojto 93:e188a91d3eaa 241 * @param __HANDLE__: DMA handle
Kojto 93:e188a91d3eaa 242 * @param __FLAG__: Get the specified flag.
Kojto 93:e188a91d3eaa 243 * This parameter can be any combination of the following values:
Kojto 93:e188a91d3eaa 244 * @arg DMA_FLAG_TCx: Transfer complete flag
Kojto 93:e188a91d3eaa 245 * @arg DMA_FLAG_HTx: Half transfer complete flag
Kojto 93:e188a91d3eaa 246 * @arg DMA_FLAG_TEx: Transfer error flag
Kojto 122:f9eeca106725 247 * Where x can be 1_7 to select the DMA Channel flag.
Kojto 93:e188a91d3eaa 248 * @retval The state of FLAG (SET or RESET).
Kojto 93:e188a91d3eaa 249 */
Kojto 93:e188a91d3eaa 250
Kojto 93:e188a91d3eaa 251 #define __HAL_DMA_GET_FLAG(__HANDLE__, __FLAG__) (DMA1->ISR & (__FLAG__))
Kojto 93:e188a91d3eaa 252
Kojto 93:e188a91d3eaa 253 /**
Kojto 93:e188a91d3eaa 254 * @brief Clears the DMA Channel pending flags.
Kojto 93:e188a91d3eaa 255 * @param __HANDLE__: DMA handle
Kojto 93:e188a91d3eaa 256 * @param __FLAG__: specifies the flag to clear.
Kojto 93:e188a91d3eaa 257 * This parameter can be any combination of the following values:
Kojto 93:e188a91d3eaa 258 * @arg DMA_FLAG_TCx: Transfer complete flag
Kojto 93:e188a91d3eaa 259 * @arg DMA_FLAG_HTx: Half transfer complete flag
Kojto 93:e188a91d3eaa 260 * @arg DMA_FLAG_TEx: Transfer error flag
Kojto 122:f9eeca106725 261 * Where x can be 1_7 to select the DMA Channel flag.
Kojto 93:e188a91d3eaa 262 * @retval None
Kojto 93:e188a91d3eaa 263 */
Kojto 122:f9eeca106725 264 #define __HAL_DMA_CLEAR_FLAG(__HANDLE__, __FLAG__) (DMA1->IFCR = (__FLAG__))
Kojto 93:e188a91d3eaa 265
Kojto 93:e188a91d3eaa 266 /**
Kojto 93:e188a91d3eaa 267 * @}
Kojto 93:e188a91d3eaa 268 */
Kojto 93:e188a91d3eaa 269
Kojto 93:e188a91d3eaa 270 #endif
Kojto 93:e188a91d3eaa 271
Kojto 93:e188a91d3eaa 272 /**
Kojto 93:e188a91d3eaa 273 * @}
Kojto 93:e188a91d3eaa 274 */
Kojto 93:e188a91d3eaa 275
Kojto 93:e188a91d3eaa 276 /**
Kojto 93:e188a91d3eaa 277 * @}
Kojto 93:e188a91d3eaa 278 */
Kojto 93:e188a91d3eaa 279
Kojto 93:e188a91d3eaa 280 /**
Kojto 93:e188a91d3eaa 281 * @}
Kojto 93:e188a91d3eaa 282 */
Kojto 93:e188a91d3eaa 283
Kojto 93:e188a91d3eaa 284 #ifdef __cplusplus
Kojto 93:e188a91d3eaa 285 }
Kojto 93:e188a91d3eaa 286 #endif /* STM32F302xE || STM32F303xE || STM32F398xx || */
Kojto 93:e188a91d3eaa 287 /* STM32F302xC || STM32F303xC || STM32F358xx || */
Kojto 93:e188a91d3eaa 288 /* STM32F373xC || STM32F378xx */
Kojto 93:e188a91d3eaa 289
Kojto 93:e188a91d3eaa 290 #endif /* __STM32F3xx_HAL_DMA_H */
Kojto 93:e188a91d3eaa 291
Kojto 93:e188a91d3eaa 292 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/