stm32f0xx_hal_dma_ex.h 58 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809
  1. /**
  2. ******************************************************************************
  3. * @file stm32f0xx_hal_dma_ex.h
  4. * @author MCD Application Team
  5. * @brief Header file of DMA HAL Extension module.
  6. ******************************************************************************
  7. * @attention
  8. *
  9. * Copyright (c) 2016 STMicroelectronics.
  10. * All rights reserved.
  11. *
  12. * This software is licensed under terms that can be found in the LICENSE file in
  13. * the root directory of this software component.
  14. * If no LICENSE file comes with this software, it is provided AS-IS.
  15. *
  16. ******************************************************************************
  17. */
  18. /* Define to prevent recursive inclusion -------------------------------------*/
  19. #ifndef __STM32F0xx_HAL_DMA_EX_H
  20. #define __STM32F0xx_HAL_DMA_EX_H
  21. #ifdef __cplusplus
  22. extern "C" {
  23. #endif
  24. /* Includes ------------------------------------------------------------------*/
  25. #include "stm32f0xx_hal_def.h"
  26. /** @addtogroup STM32F0xx_HAL_Driver
  27. * @{
  28. */
  29. /** @defgroup DMAEx DMAEx
  30. * @brief DMA HAL module driver
  31. * @{
  32. */
  33. /* Exported types ------------------------------------------------------------*/
  34. /* Exported constants --------------------------------------------------------*/
  35. #if defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC)
  36. /** @defgroup DMAEx_Exported_Constants DMAEx Exported Constants
  37. * @{
  38. */
  39. #define DMA1_CHANNEL1_RMP 0x00000000 /*!< Internal define for remapping on STM32F09x/30xC */
  40. #define DMA1_CHANNEL2_RMP 0x10000000 /*!< Internal define for remapping on STM32F09x/30xC */
  41. #define DMA1_CHANNEL3_RMP 0x20000000 /*!< Internal define for remapping on STM32F09x/30xC */
  42. #define DMA1_CHANNEL4_RMP 0x30000000 /*!< Internal define for remapping on STM32F09x/30xC */
  43. #define DMA1_CHANNEL5_RMP 0x40000000 /*!< Internal define for remapping on STM32F09x/30xC */
  44. #if !defined(STM32F030xC)
  45. #define DMA1_CHANNEL6_RMP 0x50000000 /*!< Internal define for remapping on STM32F09x/30xC */
  46. #define DMA1_CHANNEL7_RMP 0x60000000 /*!< Internal define for remapping on STM32F09x/30xC */
  47. #define DMA2_CHANNEL1_RMP 0x00000000 /*!< Internal define for remapping on STM32F09x/30xC */
  48. #define DMA2_CHANNEL2_RMP 0x10000000 /*!< Internal define for remapping on STM32F09x/30xC */
  49. #define DMA2_CHANNEL3_RMP 0x20000000 /*!< Internal define for remapping on STM32F09x/30xC */
  50. #define DMA2_CHANNEL4_RMP 0x30000000 /*!< Internal define for remapping on STM32F09x/30xC */
  51. #define DMA2_CHANNEL5_RMP 0x40000000 /*!< Internal define for remapping on STM32F09x/30xC */
  52. #endif /* !defined(STM32F030xC) */
  53. /****************** DMA1 remap bit field definition********************/
  54. /* DMA1 - Channel 1 */
  55. #define HAL_DMA1_CH1_DEFAULT (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_DEFAULT) /*!< Default remap position for DMA1 */
  56. #define HAL_DMA1_CH1_ADC (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_ADC) /*!< Remap ADC on DMA1 Channel 1*/
  57. #define HAL_DMA1_CH1_TIM17_CH1 (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_TIM17_CH1) /*!< Remap TIM17 channel 1 on DMA1 channel 1 */
  58. #define HAL_DMA1_CH1_TIM17_UP (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_TIM17_UP) /*!< Remap TIM17 up on DMA1 channel 1 */
  59. #define HAL_DMA1_CH1_USART1_RX (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_USART1_RX) /*!< Remap USART1 Rx on DMA1 channel 1 */
  60. #define HAL_DMA1_CH1_USART2_RX (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_USART2_RX) /*!< Remap USART2 Rx on DMA1 channel 1 */
  61. #define HAL_DMA1_CH1_USART3_RX (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_USART3_RX) /*!< Remap USART3 Rx on DMA1 channel 1 */
  62. #define HAL_DMA1_CH1_USART4_RX (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_USART4_RX) /*!< Remap USART4 Rx on DMA1 channel 1 */
  63. #define HAL_DMA1_CH1_USART5_RX (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_USART5_RX) /*!< Remap USART5 Rx on DMA1 channel 1 */
  64. #define HAL_DMA1_CH1_USART6_RX (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_USART6_RX) /*!< Remap USART6 Rx on DMA1 channel 1 */
  65. #if !defined(STM32F030xC)
  66. #define HAL_DMA1_CH1_USART7_RX (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_USART7_RX) /*!< Remap USART7 Rx on DMA1 channel 1 */
  67. #define HAL_DMA1_CH1_USART8_RX (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_USART8_RX) /*!< Remap USART8 Rx on DMA1 channel 1 */
  68. #endif /* !defined(STM32F030xC) */
  69. /* DMA1 - Channel 2 */
  70. #define HAL_DMA1_CH2_DEFAULT (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_DEFAULT) /*!< Default remap position for DMA1 */
  71. #define HAL_DMA1_CH2_ADC (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_ADC) /*!< Remap ADC on DMA1 channel 2 */
  72. #define HAL_DMA1_CH2_I2C1_TX (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_I2C1_TX) /*!< Remap I2C1 Tx on DMA1 channel 2 */
  73. #define HAL_DMA1_CH2_SPI1_RX (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_SPI1_RX) /*!< Remap SPI1 Rx on DMA1 channel 2 */
  74. #define HAL_DMA1_CH2_TIM1_CH1 (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_TIM1_CH1) /*!< Remap TIM1 channel 1 on DMA1 channel 2 */
  75. #define HAL_DMA1_CH2_TIM17_CH1 (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_TIM17_CH1) /*!< Remap TIM17 channel 1 on DMA1 channel 2 */
  76. #define HAL_DMA1_CH2_TIM17_UP (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_TIM17_UP) /*!< Remap TIM17 up on DMA1 channel 2 */
  77. #define HAL_DMA1_CH2_USART1_TX (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_USART1_TX) /*!< Remap USART1 Tx on DMA1 channel 2 */
  78. #define HAL_DMA1_CH2_USART2_TX (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_USART2_TX) /*!< Remap USART2 Tx on DMA1 channel 2 */
  79. #define HAL_DMA1_CH2_USART3_TX (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_USART3_TX) /*!< Remap USART3 Tx on DMA1 channel 2 */
  80. #define HAL_DMA1_CH2_USART4_TX (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_USART4_TX) /*!< Remap USART4 Tx on DMA1 channel 2 */
  81. #define HAL_DMA1_CH2_USART5_TX (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_USART5_TX) /*!< Remap USART5 Tx on DMA1 channel 2 */
  82. #define HAL_DMA1_CH2_USART6_TX (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_USART6_TX) /*!< Remap USART6 Tx on DMA1 channel 2 */
  83. #if !defined(STM32F030xC)
  84. #define HAL_DMA1_CH2_USART7_TX (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_USART7_TX) /*!< Remap USART7 Tx on DMA1 channel 2 */
  85. #define HAL_DMA1_CH2_USART8_TX (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_USART8_TX) /*!< Remap USART8 Tx on DMA1 channel 2 */
  86. #endif /* !defined(STM32F030xC) */
  87. /* DMA1 - Channel 3 */
  88. #define HAL_DMA1_CH3_DEFAULT (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_DEFAULT) /*!< Default remap position for DMA1 */
  89. #define HAL_DMA1_CH3_TIM6_UP (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_TIM6_UP) /*!< Remap TIM6 up on DMA1 channel 3 */
  90. #if !defined(STM32F030xC)
  91. #define HAL_DMA1_CH3_DAC_CH1 (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_DAC_CH1) /*!< Remap DAC Channel 1on DMA1 channel 3 */
  92. #endif /* !defined(STM32F030xC) */
  93. #define HAL_DMA1_CH3_I2C1_RX (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_I2C1_RX) /*!< Remap I2C1 Rx on DMA1 channel 3 */
  94. #define HAL_DMA1_CH3_SPI1_TX (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_SPI1_TX) /*!< Remap SPI1 Tx on DMA1 channel 3 */
  95. #define HAL_DMA1_CH3_TIM1_CH2 (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_TIM1_CH2) /*!< Remap TIM1 channel 2 on DMA1 channel 3 */
  96. #if !defined(STM32F030xC)
  97. #define HAL_DMA1_CH3_TIM2_CH2 (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_TIM2_CH2) /*!< Remap TIM2 channel 2 on DMA1 channel 3 */
  98. #endif /* !defined(STM32F030xC) */
  99. #define HAL_DMA1_CH3_TIM16_CH1 (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_TIM16_CH1) /*!< Remap TIM16 channel 1 on DMA1 channel 3 */
  100. #define HAL_DMA1_CH3_TIM16_UP (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_TIM16_UP) /*!< Remap TIM16 up on DMA1 channel 3 */
  101. #define HAL_DMA1_CH3_USART1_RX (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_USART1_RX) /*!< Remap USART1 Rx on DMA1 channel 3 */
  102. #define HAL_DMA1_CH3_USART2_RX (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_USART2_RX) /*!< Remap USART2 Rx on DMA1 channel 3 */
  103. #define HAL_DMA1_CH3_USART3_RX (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_USART3_RX) /*!< Remap USART3 Rx on DMA1 channel 3 */
  104. #define HAL_DMA1_CH3_USART4_RX (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_USART4_RX) /*!< Remap USART4 Rx on DMA1 channel 3 */
  105. #define HAL_DMA1_CH3_USART5_RX (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_USART5_RX) /*!< Remap USART5 Rx on DMA1 channel 3 */
  106. #define HAL_DMA1_CH3_USART6_RX (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_USART6_RX) /*!< Remap USART6 Rx on DMA1 channel 3 */
  107. #if !defined(STM32F030xC)
  108. #define HAL_DMA1_CH3_USART7_RX (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_USART7_RX) /*!< Remap USART7 Rx on DMA1 channel 3 */
  109. #define HAL_DMA1_CH3_USART8_RX (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_USART8_RX) /*!< Remap USART8 Rx on DMA1 channel 3 */
  110. #endif /* !defined(STM32F030xC) */
  111. /* DMA1 - Channel 4 */
  112. #define HAL_DMA1_CH4_DEFAULT (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_DEFAULT) /*!< Default remap position for DMA1 */
  113. #define HAL_DMA1_CH4_TIM7_UP (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_TIM7_UP) /*!< Remap TIM7 up on DMA1 channel 4 */
  114. #if !defined(STM32F030xC)
  115. #define HAL_DMA1_CH4_DAC_CH2 (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_DAC_CH2) /*!< Remap DAC Channel 2 on DMA1 channel 4 */
  116. #endif /* !defined(STM32F030xC) */
  117. #define HAL_DMA1_CH4_I2C2_TX (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_I2C2_TX) /*!< Remap I2C2 Tx on DMA1 channel 4 */
  118. #define HAL_DMA1_CH4_SPI2_RX (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_SPI2_RX) /*!< Remap SPI2 Rx on DMA1 channel 4 */
  119. #if !defined(STM32F030xC)
  120. #define HAL_DMA1_CH4_TIM2_CH4 (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_TIM2_CH4) /*!< Remap TIM2 channel 4 on DMA1 channel 4 */
  121. #endif /* !defined(STM32F030xC) */
  122. #define HAL_DMA1_CH4_TIM3_CH1 (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_TIM3_CH1) /*!< Remap TIM3 channel 1 on DMA1 channel 4 */
  123. #define HAL_DMA1_CH4_TIM3_TRIG (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_TIM3_TRIG) /*!< Remap TIM3 Trig on DMA1 channel 4 */
  124. #define HAL_DMA1_CH4_TIM16_CH1 (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_TIM16_CH1) /*!< Remap TIM16 channel 1 on DMA1 channel 4 */
  125. #define HAL_DMA1_CH4_TIM16_UP (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_TIM16_UP) /*!< Remap TIM16 up on DMA1 channel 4 */
  126. #define HAL_DMA1_CH4_USART1_TX (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_USART1_TX) /*!< Remap USART1 Tx on DMA1 channel 4 */
  127. #define HAL_DMA1_CH4_USART2_TX (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_USART2_TX) /*!< Remap USART2 Tx on DMA1 channel 4 */
  128. #define HAL_DMA1_CH4_USART3_TX (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_USART3_TX) /*!< Remap USART3 Tx on DMA1 channel 4 */
  129. #define HAL_DMA1_CH4_USART4_TX (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_USART4_TX) /*!< Remap USART4 Tx on DMA1 channel 4 */
  130. #define HAL_DMA1_CH4_USART5_TX (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_USART5_TX) /*!< Remap USART5 Tx on DMA1 channel 4 */
  131. #define HAL_DMA1_CH4_USART6_TX (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_USART6_TX) /*!< Remap USART6 Tx on DMA1 channel 4 */
  132. #if !defined(STM32F030xC)
  133. #define HAL_DMA1_CH4_USART7_TX (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_USART7_TX) /*!< Remap USART7 Tx on DMA1 channel 4 */
  134. #define HAL_DMA1_CH4_USART8_TX (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_USART8_TX) /*!< Remap USART8 Tx on DMA1 channel 4 */
  135. #endif /* !defined(STM32F030xC) */
  136. /* DMA1 - Channel 5 */
  137. #define HAL_DMA1_CH5_DEFAULT (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_DEFAULT) /*!< Default remap position for DMA1 */
  138. #define HAL_DMA1_CH5_I2C2_RX (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_I2C2_RX) /*!< Remap I2C2 Rx on DMA1 channel 5 */
  139. #define HAL_DMA1_CH5_SPI2_TX (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_SPI2_TX) /*!< Remap SPI1 Tx on DMA1 channel 5 */
  140. #define HAL_DMA1_CH5_TIM1_CH3 (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_TIM1_CH3) /*!< Remap TIM1 channel 3 on DMA1 channel 5 */
  141. #define HAL_DMA1_CH5_USART1_RX (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_USART1_RX) /*!< Remap USART1 Rx on DMA1 channel 5 */
  142. #define HAL_DMA1_CH5_USART2_RX (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_USART2_RX) /*!< Remap USART2 Rx on DMA1 channel 5 */
  143. #define HAL_DMA1_CH5_USART3_RX (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_USART3_RX) /*!< Remap USART3 Rx on DMA1 channel 5 */
  144. #define HAL_DMA1_CH5_USART4_RX (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_USART4_RX) /*!< Remap USART4 Rx on DMA1 channel 5 */
  145. #define HAL_DMA1_CH5_USART5_RX (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_USART5_RX) /*!< Remap USART5 Rx on DMA1 channel 5 */
  146. #define HAL_DMA1_CH5_USART6_RX (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_USART6_RX) /*!< Remap USART6 Rx on DMA1 channel 5 */
  147. #if !defined(STM32F030xC)
  148. #define HAL_DMA1_CH5_USART7_RX (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_USART7_RX) /*!< Remap USART7 Rx on DMA1 channel 5 */
  149. #define HAL_DMA1_CH5_USART8_RX (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_USART8_RX) /*!< Remap USART8 Rx on DMA1 channel 5 */
  150. #endif /* !defined(STM32F030xC) */
  151. #if !defined(STM32F030xC)
  152. /* DMA1 - Channel 6 */
  153. #define HAL_DMA1_CH6_DEFAULT (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_DEFAULT) /*!< Default remap position for DMA1 */
  154. #define HAL_DMA1_CH6_I2C1_TX (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_I2C1_TX) /*!< Remap I2C1 Tx on DMA1 channel 6 */
  155. #define HAL_DMA1_CH6_SPI2_RX (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_SPI2_RX) /*!< Remap SPI2 Rx on DMA1 channel 6 */
  156. #define HAL_DMA1_CH6_TIM1_CH1 (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_TIM1_CH1) /*!< Remap TIM1 channel 1 on DMA1 channel 6 */
  157. #define HAL_DMA1_CH6_TIM1_CH2 (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_TIM1_CH2) /*!< Remap TIM1 channel 2 on DMA1 channel 6 */
  158. #define HAL_DMA1_CH6_TIM1_CH3 (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_TIM1_CH3) /*!< Remap TIM1 channel 3 on DMA1 channel 6 */
  159. #define HAL_DMA1_CH6_TIM3_CH1 (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_TIM3_CH1) /*!< Remap TIM3 channel 1 on DMA1 channel 6 */
  160. #define HAL_DMA1_CH6_TIM3_TRIG (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_TIM3_TRIG) /*!< Remap TIM3 Trig on DMA1 channel 6 */
  161. #define HAL_DMA1_CH6_TIM16_CH1 (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_TIM16_CH1) /*!< Remap TIM16 channel 1 on DMA1 channel 6 */
  162. #define HAL_DMA1_CH6_TIM16_UP (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_TIM16_UP) /*!< Remap TIM16 up on DMA1 channel 6 */
  163. #define HAL_DMA1_CH6_USART1_RX (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_USART1_RX) /*!< Remap USART1 Rx on DMA1 channel 6 */
  164. #define HAL_DMA1_CH6_USART2_RX (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_USART2_RX) /*!< Remap USART2 Rx on DMA1 channel 6 */
  165. #define HAL_DMA1_CH6_USART3_RX (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_USART3_RX) /*!< Remap USART3 Rx on DMA1 channel 6 */
  166. #define HAL_DMA1_CH6_USART4_RX (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_USART4_RX) /*!< Remap USART4 Rx on DMA1 channel 6 */
  167. #define HAL_DMA1_CH6_USART5_RX (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_USART5_RX) /*!< Remap USART5 Rx on DMA1 channel 6 */
  168. #define HAL_DMA1_CH6_USART6_RX (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_USART6_RX) /*!< Remap USART6 Rx on DMA1 channel 6 */
  169. #define HAL_DMA1_CH6_USART7_RX (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_USART7_RX) /*!< Remap USART7 Rx on DMA1 channel 6 */
  170. #define HAL_DMA1_CH6_USART8_RX (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_USART8_RX) /*!< Remap USART8 Rx on DMA1 channel 6 */
  171. /* DMA1 - Channel 7 */
  172. #define HAL_DMA1_CH7_DEFAULT (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_DEFAULT) /*!< Default remap position for DMA1 */
  173. #define HAL_DMA1_CH7_I2C1_RX (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_I2C1_RX) /*!< Remap I2C1 Rx on DMA1 channel 7 */
  174. #define HAL_DMA1_CH7_SPI2_TX (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_SPI2_TX) /*!< Remap SPI2 Tx on DMA1 channel 7 */
  175. #define HAL_DMA1_CH7_TIM2_CH2 (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_TIM2_CH2) /*!< Remap TIM2 channel 2 on DMA1 channel 7 */
  176. #define HAL_DMA1_CH7_TIM2_CH4 (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_TIM2_CH4) /*!< Remap TIM2 channel 4 on DMA1 channel 7 */
  177. #define HAL_DMA1_CH7_TIM17_CH1 (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_TIM17_CH1) /*!< Remap TIM17 channel 1 on DMA1 channel 7 */
  178. #define HAL_DMA1_CH7_TIM17_UP (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_TIM17_UP) /*!< Remap TIM17 up on DMA1 channel 7 */
  179. #define HAL_DMA1_CH7_USART1_TX (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_USART1_TX) /*!< Remap USART1 Tx on DMA1 channel 7 */
  180. #define HAL_DMA1_CH7_USART2_TX (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_USART2_TX) /*!< Remap USART2 Tx on DMA1 channel 7 */
  181. #define HAL_DMA1_CH7_USART3_TX (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_USART3_TX) /*!< Remap USART3 Tx on DMA1 channel 7 */
  182. #define HAL_DMA1_CH7_USART4_TX (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_USART4_TX) /*!< Remap USART4 Tx on DMA1 channel 7 */
  183. #define HAL_DMA1_CH7_USART5_TX (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_USART5_TX) /*!< Remap USART5 Tx on DMA1 channel 7 */
  184. #define HAL_DMA1_CH7_USART6_TX (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_USART6_TX) /*!< Remap USART6 Tx on DMA1 channel 7 */
  185. #define HAL_DMA1_CH7_USART7_TX (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_USART7_TX) /*!< Remap USART7 Tx on DMA1 channel 7 */
  186. #define HAL_DMA1_CH7_USART8_TX (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_USART8_TX) /*!< Remap USART8 Tx on DMA1 channel 7 */
  187. /****************** DMA2 remap bit field definition********************/
  188. /* DMA2 - Channel 1 */
  189. #define HAL_DMA2_CH1_DEFAULT (uint32_t) (DMA2_CHANNEL1_RMP | DMA2_CSELR_DEFAULT) /*!< Default remap position for DMA2 */
  190. #define HAL_DMA2_CH1_I2C2_TX (uint32_t) (DMA2_CHANNEL1_RMP | DMA2_CSELR_CH1_I2C2_TX) /*!< Remap I2C2 TX on DMA2 channel 1 */
  191. #define HAL_DMA2_CH1_USART1_TX (uint32_t) (DMA2_CHANNEL1_RMP | DMA2_CSELR_CH1_USART1_TX) /*!< Remap USART1 Tx on DMA2 channel 1 */
  192. #define HAL_DMA2_CH1_USART2_TX (uint32_t) (DMA2_CHANNEL1_RMP | DMA2_CSELR_CH1_USART2_TX) /*!< Remap USART2 Tx on DMA2 channel 1 */
  193. #define HAL_DMA2_CH1_USART3_TX (uint32_t) (DMA2_CHANNEL1_RMP | DMA2_CSELR_CH1_USART3_TX) /*!< Remap USART3 Tx on DMA2 channel 1 */
  194. #define HAL_DMA2_CH1_USART4_TX (uint32_t) (DMA2_CHANNEL1_RMP | DMA2_CSELR_CH1_USART4_TX) /*!< Remap USART4 Tx on DMA2 channel 1 */
  195. #define HAL_DMA2_CH1_USART5_TX (uint32_t) (DMA2_CHANNEL1_RMP | DMA2_CSELR_CH1_USART5_TX) /*!< Remap USART5 Tx on DMA2 channel 1 */
  196. #define HAL_DMA2_CH1_USART6_TX (uint32_t) (DMA2_CHANNEL1_RMP | DMA2_CSELR_CH1_USART6_TX) /*!< Remap USART6 Tx on DMA2 channel 1 */
  197. #define HAL_DMA2_CH1_USART7_TX (uint32_t) (DMA2_CHANNEL1_RMP | DMA2_CSELR_CH1_USART7_TX) /*!< Remap USART7 Tx on DMA2 channel 1 */
  198. #define HAL_DMA2_CH1_USART8_TX (uint32_t) (DMA2_CHANNEL1_RMP | DMA2_CSELR_CH1_USART8_TX) /*!< Remap USART8 Tx on DMA2 channel 1 */
  199. /* DMA2 - Channel 2 */
  200. #define HAL_DMA2_CH2_DEFAULT (uint32_t) (DMA2_CHANNEL2_RMP | DMA2_CSELR_DEFAULT) /*!< Default remap position for DMA2 */
  201. #define HAL_DMA2_CH2_I2C2_RX (uint32_t) (DMA2_CHANNEL2_RMP | DMA2_CSELR_CH2_I2C2_RX) /*!< Remap I2C2 Rx on DMA2 channel 2 */
  202. #define HAL_DMA2_CH2_USART1_RX (uint32_t) (DMA2_CHANNEL2_RMP | DMA2_CSELR_CH2_USART1_RX) /*!< Remap USART1 Rx on DMA2 channel 2 */
  203. #define HAL_DMA2_CH2_USART2_RX (uint32_t) (DMA2_CHANNEL2_RMP | DMA2_CSELR_CH2_USART2_RX) /*!< Remap USART2 Rx on DMA2 channel 2 */
  204. #define HAL_DMA2_CH2_USART3_RX (uint32_t) (DMA2_CHANNEL2_RMP | DMA2_CSELR_CH2_USART3_RX) /*!< Remap USART3 Rx on DMA2 channel 2 */
  205. #define HAL_DMA2_CH2_USART4_RX (uint32_t) (DMA2_CHANNEL2_RMP | DMA2_CSELR_CH2_USART4_RX) /*!< Remap USART4 Rx on DMA2 channel 2 */
  206. #define HAL_DMA2_CH2_USART5_RX (uint32_t) (DMA2_CHANNEL2_RMP | DMA2_CSELR_CH2_USART5_RX) /*!< Remap USART5 Rx on DMA2 channel 2 */
  207. #define HAL_DMA2_CH2_USART6_RX (uint32_t) (DMA2_CHANNEL2_RMP | DMA2_CSELR_CH2_USART6_RX) /*!< Remap USART6 Rx on DMA2 channel 2 */
  208. #define HAL_DMA2_CH2_USART7_RX (uint32_t) (DMA2_CHANNEL2_RMP | DMA2_CSELR_CH2_USART7_RX) /*!< Remap USART7 Rx on DMA2 channel 2 */
  209. #define HAL_DMA2_CH2_USART8_RX (uint32_t) (DMA2_CHANNEL2_RMP | DMA2_CSELR_CH2_USART8_RX) /*!< Remap USART8 Rx on DMA2 channel 2 */
  210. /* DMA2 - Channel 3 */
  211. #define HAL_DMA2_CH3_DEFAULT (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_DEFAULT) /*!< Default remap position for DMA2 */
  212. #define HAL_DMA2_CH3_TIM6_UP (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_TIM6_UP) /*!< Remap TIM6 up on DMA2 channel 3 */
  213. #define HAL_DMA2_CH3_DAC_CH1 (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_DAC_CH1) /*!< Remap DAC channel 1 on DMA2 channel 3 */
  214. #define HAL_DMA2_CH3_SPI1_RX (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_SPI1_RX) /*!< Remap SPI1 Rx on DMA2 channel 3 */
  215. #define HAL_DMA2_CH3_USART1_RX (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_USART1_RX) /*!< Remap USART1 Rx on DMA2 channel 3 */
  216. #define HAL_DMA2_CH3_USART2_RX (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_USART2_RX) /*!< Remap USART2 Rx on DMA2 channel 3 */
  217. #define HAL_DMA2_CH3_USART3_RX (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_USART3_RX) /*!< Remap USART3 Rx on DMA2 channel 3 */
  218. #define HAL_DMA2_CH3_USART4_RX (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_USART4_RX) /*!< Remap USART4 Rx on DMA2 channel 3 */
  219. #define HAL_DMA2_CH3_USART5_RX (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_USART5_RX) /*!< Remap USART5 Rx on DMA2 channel 3 */
  220. #define HAL_DMA2_CH3_USART6_RX (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_USART6_RX) /*!< Remap USART6 Rx on DMA2 channel 3 */
  221. #define HAL_DMA2_CH3_USART7_RX (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_USART7_RX) /*!< Remap USART7 Rx on DMA2 channel 3 */
  222. #define HAL_DMA2_CH3_USART8_RX (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_USART8_RX) /*!< Remap USART8 Rx on DMA2 channel 3 */
  223. /* DMA2 - Channel 4 */
  224. #define HAL_DMA2_CH4_DEFAULT (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_DEFAULT) /*!< Default remap position for DMA2 */
  225. #define HAL_DMA2_CH4_TIM7_UP (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_TIM7_UP) /*!< Remap TIM7 up on DMA2 channel 4 */
  226. #define HAL_DMA2_CH4_DAC_CH2 (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_DAC_CH2) /*!< Remap DAC channel 2 on DMA2 channel 4 */
  227. #define HAL_DMA2_CH4_SPI1_TX (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_SPI1_TX) /*!< Remap SPI1 Tx on DMA2 channel 4 */
  228. #define HAL_DMA2_CH4_USART1_TX (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_USART1_TX) /*!< Remap USART1 Tx on DMA2 channel 4 */
  229. #define HAL_DMA2_CH4_USART2_TX (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_USART2_TX) /*!< Remap USART2 Tx on DMA2 channel 4 */
  230. #define HAL_DMA2_CH4_USART3_TX (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_USART3_TX) /*!< Remap USART3 Tx on DMA2 channel 4 */
  231. #define HAL_DMA2_CH4_USART4_TX (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_USART4_TX) /*!< Remap USART4 Tx on DMA2 channel 4 */
  232. #define HAL_DMA2_CH4_USART5_TX (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_USART5_TX) /*!< Remap USART5 Tx on DMA2 channel 4 */
  233. #define HAL_DMA2_CH4_USART6_TX (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_USART6_TX) /*!< Remap USART6 Tx on DMA2 channel 4 */
  234. #define HAL_DMA2_CH4_USART7_TX (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_USART7_TX) /*!< Remap USART7 Tx on DMA2 channel 4 */
  235. #define HAL_DMA2_CH4_USART8_TX (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_USART8_TX) /*!< Remap USART8 Tx on DMA2 channel 4 */
  236. /* DMA2 - Channel 5 */
  237. #define HAL_DMA2_CH5_DEFAULT (uint32_t) (DMA2_CHANNEL5_RMP | DMA2_CSELR_DEFAULT) /*!< Default remap position for DMA2 */
  238. #define HAL_DMA2_CH5_ADC (uint32_t) (DMA2_CHANNEL5_RMP | DMA2_CSELR_CH5_ADC) /*!< Remap ADC on DMA2 channel 5 */
  239. #define HAL_DMA2_CH5_USART1_TX (uint32_t) (DMA2_CHANNEL5_RMP | DMA2_CSELR_CH5_USART1_TX) /*!< Remap USART1 Tx on DMA2 channel 5 */
  240. #define HAL_DMA2_CH5_USART2_TX (uint32_t) (DMA2_CHANNEL5_RMP | DMA2_CSELR_CH5_USART2_TX) /*!< Remap USART2 Tx on DMA2 channel 5 */
  241. #define HAL_DMA2_CH5_USART3_TX (uint32_t) (DMA2_CHANNEL5_RMP | DMA2_CSELR_CH5_USART3_TX) /*!< Remap USART3 Tx on DMA2 channel 5 */
  242. #define HAL_DMA2_CH5_USART4_TX (uint32_t) (DMA2_CHANNEL5_RMP | DMA2_CSELR_CH5_USART4_TX) /*!< Remap USART4 Tx on DMA2 channel 5 */
  243. #define HAL_DMA2_CH5_USART5_TX (uint32_t) (DMA2_CHANNEL5_RMP | DMA2_CSELR_CH5_USART5_TX) /*!< Remap USART5 Tx on DMA2 channel 5 */
  244. #define HAL_DMA2_CH5_USART6_TX (uint32_t) (DMA2_CHANNEL5_RMP | DMA2_CSELR_CH5_USART6_TX) /*!< Remap USART6 Tx on DMA2 channel 5 */
  245. #define HAL_DMA2_CH5_USART7_TX (uint32_t) (DMA2_CHANNEL5_RMP | DMA2_CSELR_CH5_USART7_TX) /*!< Remap USART7 Tx on DMA2 channel 5 */
  246. #define HAL_DMA2_CH5_USART8_TX (uint32_t) (DMA2_CHANNEL5_RMP | DMA2_CSELR_CH5_USART8_TX) /*!< Remap USART8 Tx on DMA2 channel 5 */
  247. #endif /* !defined(STM32F030xC) */
  248. #if defined(STM32F091xC) || defined(STM32F098xx)
  249. #define IS_HAL_DMA1_REMAP(REQUEST) (((REQUEST) == HAL_DMA1_CH1_DEFAULT) ||\
  250. ((REQUEST) == HAL_DMA1_CH1_ADC) ||\
  251. ((REQUEST) == HAL_DMA1_CH1_TIM17_CH1) ||\
  252. ((REQUEST) == HAL_DMA1_CH1_TIM17_UP) ||\
  253. ((REQUEST) == HAL_DMA1_CH1_USART1_RX) ||\
  254. ((REQUEST) == HAL_DMA1_CH1_USART2_RX) ||\
  255. ((REQUEST) == HAL_DMA1_CH1_USART3_RX) ||\
  256. ((REQUEST) == HAL_DMA1_CH1_USART4_RX) ||\
  257. ((REQUEST) == HAL_DMA1_CH1_USART5_RX) ||\
  258. ((REQUEST) == HAL_DMA1_CH1_USART6_RX) ||\
  259. ((REQUEST) == HAL_DMA1_CH1_USART7_RX) ||\
  260. ((REQUEST) == HAL_DMA1_CH1_USART8_RX) ||\
  261. ((REQUEST) == HAL_DMA1_CH2_DEFAULT) ||\
  262. ((REQUEST) == HAL_DMA1_CH2_ADC) ||\
  263. ((REQUEST) == HAL_DMA1_CH2_I2C1_TX) ||\
  264. ((REQUEST) == HAL_DMA1_CH2_SPI1_RX) ||\
  265. ((REQUEST) == HAL_DMA1_CH2_TIM1_CH1) ||\
  266. ((REQUEST) == HAL_DMA1_CH2_I2C1_TX) ||\
  267. ((REQUEST) == HAL_DMA1_CH2_TIM17_CH1) ||\
  268. ((REQUEST) == HAL_DMA1_CH2_TIM17_UP) ||\
  269. ((REQUEST) == HAL_DMA1_CH2_USART1_TX) ||\
  270. ((REQUEST) == HAL_DMA1_CH2_USART2_TX) ||\
  271. ((REQUEST) == HAL_DMA1_CH2_USART3_TX) ||\
  272. ((REQUEST) == HAL_DMA1_CH2_USART4_TX) ||\
  273. ((REQUEST) == HAL_DMA1_CH2_USART5_TX) ||\
  274. ((REQUEST) == HAL_DMA1_CH2_USART6_TX) ||\
  275. ((REQUEST) == HAL_DMA1_CH2_USART7_TX) ||\
  276. ((REQUEST) == HAL_DMA1_CH2_USART8_TX) ||\
  277. ((REQUEST) == HAL_DMA1_CH3_DEFAULT) ||\
  278. ((REQUEST) == HAL_DMA1_CH3_TIM6_UP) ||\
  279. ((REQUEST) == HAL_DMA1_CH3_DAC_CH1) ||\
  280. ((REQUEST) == HAL_DMA1_CH3_I2C1_RX) ||\
  281. ((REQUEST) == HAL_DMA1_CH3_SPI1_TX) ||\
  282. ((REQUEST) == HAL_DMA1_CH3_TIM1_CH2) ||\
  283. ((REQUEST) == HAL_DMA1_CH3_TIM2_CH2) ||\
  284. ((REQUEST) == HAL_DMA1_CH3_TIM16_CH1) ||\
  285. ((REQUEST) == HAL_DMA1_CH3_TIM16_UP) ||\
  286. ((REQUEST) == HAL_DMA1_CH3_USART1_RX) ||\
  287. ((REQUEST) == HAL_DMA1_CH3_USART2_RX) ||\
  288. ((REQUEST) == HAL_DMA1_CH3_USART3_RX) ||\
  289. ((REQUEST) == HAL_DMA1_CH3_USART4_RX) ||\
  290. ((REQUEST) == HAL_DMA1_CH3_USART5_RX) ||\
  291. ((REQUEST) == HAL_DMA1_CH3_USART6_RX) ||\
  292. ((REQUEST) == HAL_DMA1_CH3_USART7_RX) ||\
  293. ((REQUEST) == HAL_DMA1_CH3_USART8_RX) ||\
  294. ((REQUEST) == HAL_DMA1_CH4_DEFAULT) ||\
  295. ((REQUEST) == HAL_DMA1_CH4_TIM7_UP) ||\
  296. ((REQUEST) == HAL_DMA1_CH4_DAC_CH2) ||\
  297. ((REQUEST) == HAL_DMA1_CH4_I2C2_TX) ||\
  298. ((REQUEST) == HAL_DMA1_CH4_SPI2_RX) ||\
  299. ((REQUEST) == HAL_DMA1_CH4_TIM2_CH4) ||\
  300. ((REQUEST) == HAL_DMA1_CH4_TIM3_CH1) ||\
  301. ((REQUEST) == HAL_DMA1_CH4_TIM3_TRIG) ||\
  302. ((REQUEST) == HAL_DMA1_CH4_TIM16_CH1) ||\
  303. ((REQUEST) == HAL_DMA1_CH4_TIM16_UP) ||\
  304. ((REQUEST) == HAL_DMA1_CH4_USART1_TX) ||\
  305. ((REQUEST) == HAL_DMA1_CH4_USART2_TX) ||\
  306. ((REQUEST) == HAL_DMA1_CH4_USART3_TX) ||\
  307. ((REQUEST) == HAL_DMA1_CH4_USART4_TX) ||\
  308. ((REQUEST) == HAL_DMA1_CH4_USART5_TX) ||\
  309. ((REQUEST) == HAL_DMA1_CH4_USART6_TX) ||\
  310. ((REQUEST) == HAL_DMA1_CH4_USART7_TX) ||\
  311. ((REQUEST) == HAL_DMA1_CH4_USART8_TX) ||\
  312. ((REQUEST) == HAL_DMA1_CH5_DEFAULT) ||\
  313. ((REQUEST) == HAL_DMA1_CH5_I2C2_RX) ||\
  314. ((REQUEST) == HAL_DMA1_CH5_SPI2_TX) ||\
  315. ((REQUEST) == HAL_DMA1_CH5_TIM1_CH3) ||\
  316. ((REQUEST) == HAL_DMA1_CH5_USART1_RX) ||\
  317. ((REQUEST) == HAL_DMA1_CH5_USART2_RX) ||\
  318. ((REQUEST) == HAL_DMA1_CH5_USART3_RX) ||\
  319. ((REQUEST) == HAL_DMA1_CH5_USART4_RX) ||\
  320. ((REQUEST) == HAL_DMA1_CH5_USART5_RX) ||\
  321. ((REQUEST) == HAL_DMA1_CH5_USART6_RX) ||\
  322. ((REQUEST) == HAL_DMA1_CH5_USART7_RX) ||\
  323. ((REQUEST) == HAL_DMA1_CH5_USART8_RX) ||\
  324. ((REQUEST) == HAL_DMA1_CH6_DEFAULT) ||\
  325. ((REQUEST) == HAL_DMA1_CH6_I2C1_TX) ||\
  326. ((REQUEST) == HAL_DMA1_CH6_SPI2_RX) ||\
  327. ((REQUEST) == HAL_DMA1_CH6_TIM1_CH1) ||\
  328. ((REQUEST) == HAL_DMA1_CH6_TIM1_CH2) ||\
  329. ((REQUEST) == HAL_DMA1_CH6_TIM1_CH3) ||\
  330. ((REQUEST) == HAL_DMA1_CH6_TIM3_CH1) ||\
  331. ((REQUEST) == HAL_DMA1_CH6_TIM3_TRIG) ||\
  332. ((REQUEST) == HAL_DMA1_CH6_TIM16_CH1) ||\
  333. ((REQUEST) == HAL_DMA1_CH6_TIM16_UP) ||\
  334. ((REQUEST) == HAL_DMA1_CH6_USART1_RX) ||\
  335. ((REQUEST) == HAL_DMA1_CH6_USART2_RX) ||\
  336. ((REQUEST) == HAL_DMA1_CH6_USART3_RX) ||\
  337. ((REQUEST) == HAL_DMA1_CH6_USART4_RX) ||\
  338. ((REQUEST) == HAL_DMA1_CH6_USART5_RX) ||\
  339. ((REQUEST) == HAL_DMA1_CH6_USART6_RX) ||\
  340. ((REQUEST) == HAL_DMA1_CH6_USART7_RX) ||\
  341. ((REQUEST) == HAL_DMA1_CH6_USART8_RX) ||\
  342. ((REQUEST) == HAL_DMA1_CH7_DEFAULT) ||\
  343. ((REQUEST) == HAL_DMA1_CH7_I2C1_RX) ||\
  344. ((REQUEST) == HAL_DMA1_CH7_SPI2_TX) ||\
  345. ((REQUEST) == HAL_DMA1_CH7_TIM2_CH2) ||\
  346. ((REQUEST) == HAL_DMA1_CH7_TIM2_CH4) ||\
  347. ((REQUEST) == HAL_DMA1_CH7_TIM17_CH1) ||\
  348. ((REQUEST) == HAL_DMA1_CH7_TIM17_UP) ||\
  349. ((REQUEST) == HAL_DMA1_CH7_USART1_TX) ||\
  350. ((REQUEST) == HAL_DMA1_CH7_USART2_TX) ||\
  351. ((REQUEST) == HAL_DMA1_CH7_USART3_TX) ||\
  352. ((REQUEST) == HAL_DMA1_CH7_USART4_TX) ||\
  353. ((REQUEST) == HAL_DMA1_CH7_USART5_TX) ||\
  354. ((REQUEST) == HAL_DMA1_CH7_USART6_TX) ||\
  355. ((REQUEST) == HAL_DMA1_CH7_USART7_TX) ||\
  356. ((REQUEST) == HAL_DMA1_CH7_USART8_TX))
  357. #define IS_HAL_DMA2_REMAP(REQUEST) (((REQUEST) == HAL_DMA2_CH1_DEFAULT) ||\
  358. ((REQUEST) == HAL_DMA2_CH1_I2C2_TX) ||\
  359. ((REQUEST) == HAL_DMA2_CH1_USART1_TX) ||\
  360. ((REQUEST) == HAL_DMA2_CH1_USART2_TX) ||\
  361. ((REQUEST) == HAL_DMA2_CH1_USART3_TX) ||\
  362. ((REQUEST) == HAL_DMA2_CH1_USART4_TX) ||\
  363. ((REQUEST) == HAL_DMA2_CH1_USART5_TX) ||\
  364. ((REQUEST) == HAL_DMA2_CH1_USART6_TX) ||\
  365. ((REQUEST) == HAL_DMA2_CH1_USART7_TX) ||\
  366. ((REQUEST) == HAL_DMA2_CH1_USART8_TX) ||\
  367. ((REQUEST) == HAL_DMA2_CH2_DEFAULT) ||\
  368. ((REQUEST) == HAL_DMA2_CH2_I2C2_RX) ||\
  369. ((REQUEST) == HAL_DMA2_CH2_USART1_RX) ||\
  370. ((REQUEST) == HAL_DMA2_CH2_USART2_RX) ||\
  371. ((REQUEST) == HAL_DMA2_CH2_USART3_RX) ||\
  372. ((REQUEST) == HAL_DMA2_CH2_USART4_RX) ||\
  373. ((REQUEST) == HAL_DMA2_CH2_USART5_RX) ||\
  374. ((REQUEST) == HAL_DMA2_CH2_USART6_RX) ||\
  375. ((REQUEST) == HAL_DMA2_CH2_USART7_RX) ||\
  376. ((REQUEST) == HAL_DMA2_CH2_USART8_RX) ||\
  377. ((REQUEST) == HAL_DMA2_CH3_DEFAULT) ||\
  378. ((REQUEST) == HAL_DMA2_CH3_TIM6_UP) ||\
  379. ((REQUEST) == HAL_DMA2_CH3_DAC_CH1) ||\
  380. ((REQUEST) == HAL_DMA2_CH3_SPI1_RX) ||\
  381. ((REQUEST) == HAL_DMA2_CH3_USART1_RX) ||\
  382. ((REQUEST) == HAL_DMA2_CH3_USART2_RX) ||\
  383. ((REQUEST) == HAL_DMA2_CH3_USART3_RX) ||\
  384. ((REQUEST) == HAL_DMA2_CH3_USART4_RX) ||\
  385. ((REQUEST) == HAL_DMA2_CH3_USART5_RX) ||\
  386. ((REQUEST) == HAL_DMA2_CH3_USART6_RX) ||\
  387. ((REQUEST) == HAL_DMA2_CH3_USART7_RX) ||\
  388. ((REQUEST) == HAL_DMA2_CH3_USART8_RX) ||\
  389. ((REQUEST) == HAL_DMA2_CH4_DEFAULT) ||\
  390. ((REQUEST) == HAL_DMA2_CH4_TIM7_UP) ||\
  391. ((REQUEST) == HAL_DMA2_CH4_DAC_CH2) ||\
  392. ((REQUEST) == HAL_DMA2_CH4_SPI1_TX) ||\
  393. ((REQUEST) == HAL_DMA2_CH4_USART1_TX) ||\
  394. ((REQUEST) == HAL_DMA2_CH4_USART2_TX) ||\
  395. ((REQUEST) == HAL_DMA2_CH4_USART3_TX) ||\
  396. ((REQUEST) == HAL_DMA2_CH4_USART4_TX) ||\
  397. ((REQUEST) == HAL_DMA2_CH4_USART5_TX) ||\
  398. ((REQUEST) == HAL_DMA2_CH4_USART6_TX) ||\
  399. ((REQUEST) == HAL_DMA2_CH4_USART7_TX) ||\
  400. ((REQUEST) == HAL_DMA2_CH4_USART8_TX) ||\
  401. ((REQUEST) == HAL_DMA2_CH5_DEFAULT) ||\
  402. ((REQUEST) == HAL_DMA2_CH5_ADC) ||\
  403. ((REQUEST) == HAL_DMA2_CH5_USART1_TX) ||\
  404. ((REQUEST) == HAL_DMA2_CH5_USART2_TX) ||\
  405. ((REQUEST) == HAL_DMA2_CH5_USART3_TX) ||\
  406. ((REQUEST) == HAL_DMA2_CH5_USART4_TX) ||\
  407. ((REQUEST) == HAL_DMA2_CH5_USART5_TX) ||\
  408. ((REQUEST) == HAL_DMA2_CH5_USART6_TX) ||\
  409. ((REQUEST) == HAL_DMA2_CH5_USART7_TX) ||\
  410. ((REQUEST) == HAL_DMA2_CH5_USART8_TX ))
  411. #endif /* STM32F091xC || STM32F098xx */
  412. #if defined(STM32F030xC)
  413. #define IS_HAL_DMA1_REMAP(REQUEST) (((REQUEST) == HAL_DMA1_CH1_DEFAULT) ||\
  414. ((REQUEST) == HAL_DMA1_CH1_ADC) ||\
  415. ((REQUEST) == HAL_DMA1_CH1_TIM17_CH1) ||\
  416. ((REQUEST) == HAL_DMA1_CH1_TIM17_UP) ||\
  417. ((REQUEST) == HAL_DMA1_CH1_USART1_RX) ||\
  418. ((REQUEST) == HAL_DMA1_CH1_USART2_RX) ||\
  419. ((REQUEST) == HAL_DMA1_CH1_USART3_RX) ||\
  420. ((REQUEST) == HAL_DMA1_CH1_USART4_RX) ||\
  421. ((REQUEST) == HAL_DMA1_CH1_USART5_RX) ||\
  422. ((REQUEST) == HAL_DMA1_CH1_USART6_RX) ||\
  423. ((REQUEST) == HAL_DMA1_CH2_DEFAULT) ||\
  424. ((REQUEST) == HAL_DMA1_CH2_ADC) ||\
  425. ((REQUEST) == HAL_DMA1_CH2_I2C1_TX) ||\
  426. ((REQUEST) == HAL_DMA1_CH2_SPI1_RX) ||\
  427. ((REQUEST) == HAL_DMA1_CH2_TIM1_CH1) ||\
  428. ((REQUEST) == HAL_DMA1_CH2_I2C1_TX) ||\
  429. ((REQUEST) == HAL_DMA1_CH2_TIM17_CH1) ||\
  430. ((REQUEST) == HAL_DMA1_CH2_TIM17_UP) ||\
  431. ((REQUEST) == HAL_DMA1_CH2_USART1_TX) ||\
  432. ((REQUEST) == HAL_DMA1_CH2_USART2_TX) ||\
  433. ((REQUEST) == HAL_DMA1_CH2_USART3_TX) ||\
  434. ((REQUEST) == HAL_DMA1_CH2_USART4_TX) ||\
  435. ((REQUEST) == HAL_DMA1_CH2_USART5_TX) ||\
  436. ((REQUEST) == HAL_DMA1_CH2_USART6_TX) ||\
  437. ((REQUEST) == HAL_DMA1_CH3_DEFAULT) ||\
  438. ((REQUEST) == HAL_DMA1_CH3_TIM6_UP) ||\
  439. ((REQUEST) == HAL_DMA1_CH3_I2C1_RX) ||\
  440. ((REQUEST) == HAL_DMA1_CH3_SPI1_TX) ||\
  441. ((REQUEST) == HAL_DMA1_CH3_TIM1_CH2) ||\
  442. ((REQUEST) == HAL_DMA1_CH3_TIM16_CH1) ||\
  443. ((REQUEST) == HAL_DMA1_CH3_TIM16_UP) ||\
  444. ((REQUEST) == HAL_DMA1_CH3_USART1_RX) ||\
  445. ((REQUEST) == HAL_DMA1_CH3_USART2_RX) ||\
  446. ((REQUEST) == HAL_DMA1_CH3_USART3_RX) ||\
  447. ((REQUEST) == HAL_DMA1_CH3_USART4_RX) ||\
  448. ((REQUEST) == HAL_DMA1_CH3_USART5_RX) ||\
  449. ((REQUEST) == HAL_DMA1_CH3_USART6_RX) ||\
  450. ((REQUEST) == HAL_DMA1_CH4_DEFAULT) ||\
  451. ((REQUEST) == HAL_DMA1_CH4_TIM7_UP) ||\
  452. ((REQUEST) == HAL_DMA1_CH4_I2C2_TX) ||\
  453. ((REQUEST) == HAL_DMA1_CH4_SPI2_RX) ||\
  454. ((REQUEST) == HAL_DMA1_CH4_TIM3_CH1) ||\
  455. ((REQUEST) == HAL_DMA1_CH4_TIM3_TRIG) ||\
  456. ((REQUEST) == HAL_DMA1_CH4_TIM16_CH1) ||\
  457. ((REQUEST) == HAL_DMA1_CH4_TIM16_UP) ||\
  458. ((REQUEST) == HAL_DMA1_CH4_USART1_TX) ||\
  459. ((REQUEST) == HAL_DMA1_CH4_USART2_TX) ||\
  460. ((REQUEST) == HAL_DMA1_CH4_USART3_TX) ||\
  461. ((REQUEST) == HAL_DMA1_CH4_USART4_TX) ||\
  462. ((REQUEST) == HAL_DMA1_CH4_USART5_TX) ||\
  463. ((REQUEST) == HAL_DMA1_CH4_USART6_TX) ||\
  464. ((REQUEST) == HAL_DMA1_CH5_DEFAULT) ||\
  465. ((REQUEST) == HAL_DMA1_CH5_I2C2_RX) ||\
  466. ((REQUEST) == HAL_DMA1_CH5_SPI2_TX) ||\
  467. ((REQUEST) == HAL_DMA1_CH5_TIM1_CH3) ||\
  468. ((REQUEST) == HAL_DMA1_CH5_USART1_RX) ||\
  469. ((REQUEST) == HAL_DMA1_CH5_USART2_RX) ||\
  470. ((REQUEST) == HAL_DMA1_CH5_USART3_RX) ||\
  471. ((REQUEST) == HAL_DMA1_CH5_USART4_RX) ||\
  472. ((REQUEST) == HAL_DMA1_CH5_USART5_RX) ||\
  473. ((REQUEST) == HAL_DMA1_CH5_USART6_RX))
  474. #endif /* STM32F030xC */
  475. /**
  476. * @}
  477. */
  478. #endif /* STM32F091xC || STM32F098xx || STM32F030xC */
  479. /* Exported macros -----------------------------------------------------------*/
  480. /** @defgroup DMAEx_Exported_Macros DMAEx Exported Macros
  481. * @{
  482. */
  483. /* Interrupt & Flag management */
  484. #if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)
  485. /**
  486. * @brief Returns the current DMA Channel transfer complete flag.
  487. * @param __HANDLE__ DMA handle
  488. * @retval The specified transfer complete flag index.
  489. */
  490. #define __HAL_DMA_GET_TC_FLAG_INDEX(__HANDLE__) \
  491. (((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_TC1 :\
  492. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_TC2 :\
  493. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_TC3 :\
  494. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_TC4 :\
  495. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_TC5 :\
  496. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_TC6 :\
  497. DMA_FLAG_TC7)
  498. /**
  499. * @brief Returns the current DMA Channel half transfer complete flag.
  500. * @param __HANDLE__ DMA handle
  501. * @retval The specified half transfer complete flag index.
  502. */
  503. #define __HAL_DMA_GET_HT_FLAG_INDEX(__HANDLE__)\
  504. (((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_HT1 :\
  505. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_HT2 :\
  506. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_HT3 :\
  507. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_HT4 :\
  508. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_HT5 :\
  509. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_HT6 :\
  510. DMA_FLAG_HT7)
  511. /**
  512. * @brief Returns the current DMA Channel transfer error flag.
  513. * @param __HANDLE__ DMA handle
  514. * @retval The specified transfer error flag index.
  515. */
  516. #define __HAL_DMA_GET_TE_FLAG_INDEX(__HANDLE__)\
  517. (((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_TE1 :\
  518. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_TE2 :\
  519. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_TE3 :\
  520. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_TE4 :\
  521. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_TE5 :\
  522. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_TE6 :\
  523. DMA_FLAG_TE7)
  524. /**
  525. * @brief Return the current DMA Channel Global interrupt flag.
  526. * @param __HANDLE__ DMA handle
  527. * @retval The specified transfer error flag index.
  528. */
  529. #define __HAL_DMA_GET_GI_FLAG_INDEX(__HANDLE__)\
  530. (((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_GL1 :\
  531. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_GL2 :\
  532. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_GL3 :\
  533. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_GL4 :\
  534. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_GL5 :\
  535. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_GL6 :\
  536. DMA_FLAG_GL7)
  537. /**
  538. * @brief Get the DMA Channel pending flags.
  539. * @param __HANDLE__ DMA handle
  540. * @param __FLAG__ Get the specified flag.
  541. * This parameter can be any combination of the following values:
  542. * @arg DMA_FLAG_TCx: Transfer complete flag
  543. * @arg DMA_FLAG_HTx: Half transfer complete flag
  544. * @arg DMA_FLAG_TEx: Transfer error flag
  545. * Where x can be 1_7 to select the DMA Channel flag.
  546. * @retval The state of FLAG (SET or RESET).
  547. */
  548. #define __HAL_DMA_GET_FLAG(__HANDLE__, __FLAG__) (DMA1->ISR & (__FLAG__))
  549. /**
  550. * @brief Clears the DMA Channel pending flags.
  551. * @param __HANDLE__ DMA handle
  552. * @param __FLAG__ specifies the flag to clear.
  553. * This parameter can be any combination of the following values:
  554. * @arg DMA_FLAG_TCx: Transfer complete flag
  555. * @arg DMA_FLAG_HTx: Half transfer complete flag
  556. * @arg DMA_FLAG_TEx: Transfer error flag
  557. * Where x can be 1_7 to select the DMA Channel flag.
  558. * @retval None
  559. */
  560. #define __HAL_DMA_CLEAR_FLAG(__HANDLE__, __FLAG__) (DMA1->IFCR = (__FLAG__))
  561. #elif defined(STM32F091xC) || defined(STM32F098xx)
  562. /**
  563. * @brief Returns the current DMA Channel transfer complete flag.
  564. * @param __HANDLE__ DMA handle
  565. * @retval The specified transfer complete flag index.
  566. */
  567. #define __HAL_DMA_GET_TC_FLAG_INDEX(__HANDLE__) \
  568. (((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_TC1 :\
  569. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_TC2 :\
  570. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_TC3 :\
  571. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_TC4 :\
  572. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_TC5 :\
  573. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_TC6 :\
  574. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel7))? DMA_FLAG_TC7 :\
  575. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel1))? DMA_FLAG_TC1 :\
  576. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel2))? DMA_FLAG_TC2 :\
  577. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel3))? DMA_FLAG_TC3 :\
  578. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel4))? DMA_FLAG_TC4 :\
  579. DMA_FLAG_TC5)
  580. /**
  581. * @brief Returns the current DMA Channel half transfer complete flag.
  582. * @param __HANDLE__ DMA handle
  583. * @retval The specified half transfer complete flag index.
  584. */
  585. #define __HAL_DMA_GET_HT_FLAG_INDEX(__HANDLE__)\
  586. (((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_HT1 :\
  587. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_HT2 :\
  588. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_HT3 :\
  589. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_HT4 :\
  590. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_HT5 :\
  591. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_HT6 :\
  592. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel7))? DMA_FLAG_HT7 :\
  593. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel1))? DMA_FLAG_HT1 :\
  594. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel2))? DMA_FLAG_HT2 :\
  595. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel3))? DMA_FLAG_HT3 :\
  596. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel4))? DMA_FLAG_HT4 :\
  597. DMA_FLAG_HT5)
  598. /**
  599. * @brief Returns the current DMA Channel transfer error flag.
  600. * @param __HANDLE__ DMA handle
  601. * @retval The specified transfer error flag index.
  602. */
  603. #define __HAL_DMA_GET_TE_FLAG_INDEX(__HANDLE__)\
  604. (((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_TE1 :\
  605. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_TE2 :\
  606. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_TE3 :\
  607. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_TE4 :\
  608. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_TE5 :\
  609. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_TE6 :\
  610. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel7))? DMA_FLAG_TE7 :\
  611. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel1))? DMA_FLAG_TE1 :\
  612. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel2))? DMA_FLAG_TE2 :\
  613. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel3))? DMA_FLAG_TE3 :\
  614. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel4))? DMA_FLAG_TE4 :\
  615. DMA_FLAG_TE5)
  616. /**
  617. * @brief Return the current DMA Channel Global interrupt flag.
  618. * @param __HANDLE__ DMA handle
  619. * @retval The specified transfer error flag index.
  620. */
  621. #define __HAL_DMA_GET_GI_FLAG_INDEX(__HANDLE__)\
  622. (((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_GL1 :\
  623. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_GL2 :\
  624. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_GL3 :\
  625. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_GL4 :\
  626. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_GL5 :\
  627. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_GL6 :\
  628. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel7))? DMA_FLAG_GL7 :\
  629. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel1))? DMA_FLAG_GL1 :\
  630. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel2))? DMA_FLAG_GL2 :\
  631. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel3))? DMA_FLAG_GL3 :\
  632. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel4))? DMA_FLAG_GL4 :\
  633. DMA_FLAG_GL5)
  634. /**
  635. * @brief Get the DMA Channel pending flags.
  636. * @param __HANDLE__ DMA handle
  637. * @param __FLAG__ Get the specified flag.
  638. * This parameter can be any combination of the following values:
  639. * @arg DMA_FLAG_TCx: Transfer complete flag
  640. * @arg DMA_FLAG_HTx: Half transfer complete flag
  641. * @arg DMA_FLAG_TEx: Transfer error flag
  642. * Where x can be 0_4, 1_5, 2_6 or 3_7 to select the DMA Channel flag.
  643. * @retval The state of FLAG (SET or RESET).
  644. */
  645. #define __HAL_DMA_GET_FLAG(__HANDLE__, __FLAG__)\
  646. (((uint32_t)((__HANDLE__)->Instance) > (uint32_t)DMA1_Channel7)? (DMA2->ISR & (__FLAG__)) :\
  647. (DMA1->ISR & (__FLAG__)))
  648. /**
  649. * @brief Clears the DMA Channel pending flags.
  650. * @param __HANDLE__ DMA handle
  651. * @param __FLAG__ specifies the flag to clear.
  652. * This parameter can be any combination of the following values:
  653. * @arg DMA_FLAG_TCx: Transfer complete flag
  654. * @arg DMA_FLAG_HTx: Half transfer complete flag
  655. * @arg DMA_FLAG_TEx: Transfer error flag
  656. * Where x can be 0_4, 1_5, 2_6 or 3_7 to select the DMA Channel flag.
  657. * @retval None
  658. */
  659. #define __HAL_DMA_CLEAR_FLAG(__HANDLE__, __FLAG__) \
  660. (((uint32_t)((__HANDLE__)->Instance) > (uint32_t)DMA1_Channel7)? (DMA2->IFCR = (__FLAG__)) :\
  661. (DMA1->IFCR = (__FLAG__)))
  662. #else /* STM32F030x8_STM32F030xC_STM32F031x6_STM32F038xx_STM32F051x8_STM32F058xx_STM32F070x6_STM32F070xB Product devices */
  663. /**
  664. * @brief Returns the current DMA Channel transfer complete flag.
  665. * @param __HANDLE__ DMA handle
  666. * @retval The specified transfer complete flag index.
  667. */
  668. #define __HAL_DMA_GET_TC_FLAG_INDEX(__HANDLE__) \
  669. (((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_TC1 :\
  670. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_TC2 :\
  671. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_TC3 :\
  672. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_TC4 :\
  673. DMA_FLAG_TC5)
  674. /**
  675. * @brief Returns the current DMA Channel half transfer complete flag.
  676. * @param __HANDLE__ DMA handle
  677. * @retval The specified half transfer complete flag index.
  678. */
  679. #define __HAL_DMA_GET_HT_FLAG_INDEX(__HANDLE__)\
  680. (((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_HT1 :\
  681. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_HT2 :\
  682. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_HT3 :\
  683. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_HT4 :\
  684. DMA_FLAG_HT5)
  685. /**
  686. * @brief Returns the current DMA Channel transfer error flag.
  687. * @param __HANDLE__ DMA handle
  688. * @retval The specified transfer error flag index.
  689. */
  690. #define __HAL_DMA_GET_TE_FLAG_INDEX(__HANDLE__)\
  691. (((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_TE1 :\
  692. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_TE2 :\
  693. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_TE3 :\
  694. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_TE4 :\
  695. DMA_FLAG_TE5)
  696. /**
  697. * @brief Return the current DMA Channel Global interrupt flag.
  698. * @param __HANDLE__ DMA handle
  699. * @retval The specified transfer error flag index.
  700. */
  701. #define __HAL_DMA_GET_GI_FLAG_INDEX(__HANDLE__)\
  702. (((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_GL1 :\
  703. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_GL2 :\
  704. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_GL3 :\
  705. ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_GL4 :\
  706. DMA_FLAG_GL5)
  707. /**
  708. * @brief Get the DMA Channel pending flags.
  709. * @param __HANDLE__ DMA handle
  710. * @param __FLAG__ Get the specified flag.
  711. * This parameter can be any combination of the following values:
  712. * @arg DMA_FLAG_TCx: Transfer complete flag
  713. * @arg DMA_FLAG_HTx: Half transfer complete flag
  714. * @arg DMA_FLAG_TEx: Transfer error flag
  715. * Where x can be 1_5 to select the DMA Channel flag.
  716. * @retval The state of FLAG (SET or RESET).
  717. */
  718. #define __HAL_DMA_GET_FLAG(__HANDLE__, __FLAG__) (DMA1->ISR & (__FLAG__))
  719. /**
  720. * @brief Clears the DMA Channel pending flags.
  721. * @param __HANDLE__ DMA handle
  722. * @param __FLAG__ specifies the flag to clear.
  723. * This parameter can be any combination of the following values:
  724. * @arg DMA_FLAG_TCx: Transfer complete flag
  725. * @arg DMA_FLAG_HTx: Half transfer complete flag
  726. * @arg DMA_FLAG_TEx: Transfer error flag
  727. * Where x can be 1_5 to select the DMA Channel flag.
  728. * @retval None
  729. */
  730. #define __HAL_DMA_CLEAR_FLAG(__HANDLE__, __FLAG__) (DMA1->IFCR = (__FLAG__))
  731. #endif
  732. #if defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC)
  733. #define __HAL_DMA1_REMAP(__REQUEST__) \
  734. do { assert_param(IS_HAL_DMA1_REMAP(__REQUEST__)); \
  735. DMA1->CSELR &= ~(0x0FU << (uint32_t)(((__REQUEST__) >> 28U) * 4U)); \
  736. DMA1->CSELR |= (uint32_t)((__REQUEST__) & 0x0FFFFFFFU); \
  737. }while(0)
  738. #if defined(STM32F091xC) || defined(STM32F098xx)
  739. #define __HAL_DMA2_REMAP(__REQUEST__) \
  740. do { assert_param(IS_HAL_DMA2_REMAP(__REQUEST__)); \
  741. DMA2->CSELR &= ~(0x0FU << (uint32_t)(((__REQUEST__) >> 28U) * 4U)); \
  742. DMA2->CSELR |= (uint32_t)((__REQUEST__) & 0x0FFFFFFFU); \
  743. }while(0)
  744. #endif /* STM32F091xC || STM32F098xx */
  745. #endif /* STM32F091xC || STM32F098xx || STM32F030xC */
  746. /**
  747. * @}
  748. */
  749. /**
  750. * @}
  751. */
  752. /**
  753. * @}
  754. */
  755. #ifdef __cplusplus
  756. }
  757. #endif
  758. #endif /* __STM32F0xx_HAL_DMA_EX_H */