mbed official / mbed

Dependents:   hello SerialTestv11 SerialTestv12 Sierpinski ... more

Committer:
Kojto
Date:
Fri Aug 12 13:04:35 2016 +0200
Revision:
123:b0220dba8be7
Parent:
122:f9eeca106725
Release 123 of the mbed library

Changes:
- new targets: nucleo_f207zg, beetle, nrf51_dk, hexiwear,
nuvoton nuc472, vk rz a1h
- ST - fix timer interrupt handler, sleep api fix
- NXP - lpc15xx us ticker fix
- Nordic - analogin fixes, LF clock init addition, enable i2c async

Who changed what in which revision?

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