dma_config.h 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. /*
  2. * Copyright (c) 2006-2021, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * Date Author Notes
  9. * 2020-10-14 Dozingfiretruck first version
  10. */
  11. #ifndef __DMA_CONFIG_H__
  12. #define __DMA_CONFIG_H__
  13. #include <rtthread.h>
  14. #ifdef __cplusplus
  15. extern "C" {
  16. #endif
  17. /* DMA1 channel1 */
  18. /* DMA1 channel2 */
  19. #if defined(BSP_SPI1_RX_USING_DMA) && !defined(SPI1_RX_DMA_INSTANCE)
  20. #define SPI1_DMA_RX_IRQHandler DMA1_Channel2_IRQHandler
  21. #define SPI1_RX_DMA_RCC RCC_AHB1ENR_DMA1EN
  22. #define SPI1_RX_DMA_INSTANCE DMA1_Channel2
  23. #if defined(DMAMUX1) /* for L4+ */
  24. #define SPI1_RX_DMA_REQUEST DMA_REQUEST_SPI1_RX
  25. #else /* for L4 */
  26. #define SPI1_RX_DMA_REQUEST DMA_REQUEST_1
  27. #endif /* DMAMUX1 */
  28. #define SPI1_RX_DMA_IRQ DMA1_Channel2_IRQn
  29. #endif
  30. /* DMA1 channel3 */
  31. #if defined(BSP_SPI1_TX_USING_DMA) && !defined(SPI1_TX_DMA_INSTANCE)
  32. #define SPI1_DMA_TX_IRQHandler DMA1_Channel3_IRQHandler
  33. #define SPI1_TX_DMA_RCC RCC_AHB1ENR_DMA1EN
  34. #define SPI1_TX_DMA_INSTANCE DMA1_Channel3
  35. #if defined(DMAMUX1) /* for L4+ */
  36. #define SPI1_TX_DMA_REQUEST DMA_REQUEST_SPI1_TX
  37. #else /* for L4 */
  38. #define SPI1_TX_DMA_REQUEST DMA_REQUEST_1
  39. #endif /* DMAMUX1 */
  40. #define SPI1_TX_DMA_IRQ DMA1_Channel3_IRQn
  41. #elif defined(BSP_UART3_RX_USING_DMA) && !defined(UART3_RX_DMA_INSTANCE)
  42. #define UART3_DMA_RX_IRQHandler DMA1_Channel3_IRQHandler
  43. #define UART3_RX_DMA_RCC RCC_AHB1ENR_DMA1EN
  44. #define UART3_RX_DMA_INSTANCE DMA1_Channel3
  45. #if defined(DMAMUX1) /* for L4+ */
  46. #define UART3_RX_DMA_REQUEST DMA_REQUEST_USART3_RX
  47. #else /* for L4 */
  48. #define UART3_RX_DMA_REQUEST DMA_REQUEST_2
  49. #endif /* DMAMUX1 */
  50. #define UART3_RX_DMA_IRQ DMA1_Channel3_IRQn
  51. #endif
  52. /* DMA1 channel4 */
  53. #if defined(BSP_UART1_TX_USING_DMA) && !defined(UART1_TX_DMA_INSTANCE)
  54. #define UART1_DMA_TX_IRQHandler DMA1_Channel4_IRQHandler
  55. #define UART1_TX_DMA_RCC RCC_AHB1ENR_DMA1EN
  56. #define UART1_TX_DMA_INSTANCE DMA1_Channel4
  57. #if defined(DMAMUX1) /* for L4+ */
  58. #define UART1_TX_DMA_REQUEST DMA_REQUEST_USART1_TX
  59. #else /* for L4 */
  60. #define UART1_TX_DMA_REQUEST DMA_REQUEST_2
  61. #endif /* DMAMUX1 */
  62. #define UART1_TX_DMA_IRQ DMA1_Channel4_IRQn
  63. #elif defined(BSP_SPI2_RX_USING_DMA) && !defined(SPI2_RX_DMA_INSTANCE)
  64. #define SPI2_DMA_RX_IRQHandler DMA1_Channel4_IRQHandler
  65. #define SPI2_RX_DMA_RCC RCC_AHB1ENR_DMA1EN
  66. #define SPI2_RX_DMA_INSTANCE DMA1_Channel4
  67. #if defined(DMAMUX1) /* for L4+ */
  68. #define SPI2_RX_DMA_REQUEST DMA_REQUEST_SPI2_RX
  69. #else /* for L4 */
  70. #define SPI2_RX_DMA_REQUEST DMA_REQUEST_1
  71. #endif /* DMAMUX1 */
  72. #define SPI2_RX_DMA_IRQ DMA1_Channel4_IRQn
  73. #endif
  74. /* DMA1 channel5 */
  75. #if defined(BSP_UART1_RX_USING_DMA) && !defined(UART1_RX_DMA_INSTANCE)
  76. #define UART1_DMA_RX_IRQHandler DMA1_Channel5_IRQHandler
  77. #define UART1_RX_DMA_RCC RCC_AHB1ENR_DMA1EN
  78. #define UART1_RX_DMA_INSTANCE DMA1_Channel5
  79. #if defined(DMAMUX1) /* for L4+ */
  80. #define UART1_RX_DMA_REQUEST DMA_REQUEST_USART1_RX
  81. #else /* for L4 */
  82. #define UART1_RX_DMA_REQUEST DMA_REQUEST_2
  83. #endif /* DMAMUX1 */
  84. #define UART1_RX_DMA_IRQ DMA1_Channel5_IRQn
  85. #elif defined(BSP_QSPI_USING_DMA) && !defined(QSPI_DMA_INSTANCE)
  86. #define QSPI_DMA_IRQHandler DMA1_Channel5_IRQHandler
  87. #define QSPI_DMA_RCC RCC_AHB1ENR_DMA1EN
  88. #define QSPI_DMA_INSTANCE DMA1_Channel5
  89. #if defined(DMAMUX1) /* for L4+ */
  90. #define QSPI_DMA_REQUEST DMA_REQUEST_OCTOSPI1
  91. #else /* for L4 */
  92. #define QSPI_DMA_REQUEST DMA_REQUEST_5
  93. #endif /* DMAMUX1 */
  94. #define QSPI_DMA_IRQ DMA1_Channel5_IRQn
  95. #elif defined(BSP_SPI2_TX_USING_DMA) && !defined(SPI2_TX_DMA_INSTANCE)
  96. #define SPI2_DMA_TX_IRQHandler DMA1_Channel5_IRQHandler
  97. #define SPI2_TX_DMA_RCC RCC_AHB1ENR_DMA1EN
  98. #define SPI2_TX_DMA_INSTANCE DMA1_Channel5
  99. #if defined(DMAMUX1) /* for L4+ */
  100. #define SPI2_TX_DMA_REQUEST DMA_REQUEST_SPI2_TX
  101. #else /* for L4 */
  102. #define SPI2_TX_DMA_REQUEST DMA_REQUEST_1
  103. #endif /* DMAMUX1 */
  104. #define SPI2_TX_DMA_IRQ DMA1_Channel5_IRQn
  105. #endif
  106. /* DMA1 channel6 */
  107. #if defined(BSP_UART2_RX_USING_DMA) && !defined(UART2_RX_DMA_INSTANCE)
  108. #define UART2_DMA_RX_IRQHandler DMA1_Channel6_IRQHandler
  109. #define UART2_RX_DMA_RCC RCC_AHB1ENR_DMA1EN
  110. #define UART2_RX_DMA_INSTANCE DMA1_Channel6
  111. #if defined(DMAMUX1) /* for L4+ */
  112. #define UART2_RX_DMA_REQUEST DMA_REQUEST_USART2_RX
  113. #else /* for L4 */
  114. #define UART2_RX_DMA_REQUEST DMA_REQUEST_2
  115. #endif /* DMAMUX1 */
  116. #define UART2_RX_DMA_IRQ DMA1_Channel6_IRQn
  117. #endif
  118. /* DMA1 channel7 */
  119. /* DMA2 channel1 */
  120. #if defined(BSP_UART5_TX_USING_DMA) && !defined(UART5_TX_DMA_INSTANCE)
  121. #define UART5_DMA_TX_IRQHandler DMA2_Channel1_IRQHandler
  122. #define UART5_TX_DMA_RCC RCC_AHB1ENR_DMA2EN
  123. #define UART5_TX_DMA_INSTANCE DMA2_Channel1
  124. #if defined(DMAMUX1) /* for L4+ */
  125. #define UART5_TX_DMA_REQUEST DMA_REQUEST_UART5_TX
  126. #else /* for L4 */
  127. #define UART5_TX_DMA_REQUEST DMA_REQUEST_2
  128. #endif /* DMAMUX1 */
  129. #define UART5_TX_DMA_IRQ DMA2_Channel1_IRQn
  130. #endif
  131. /* DMA2 channel2 */
  132. #if defined(BSP_UART5_RX_USING_DMA) && !defined(UART5_RX_DMA_INSTANCE)
  133. #define UART5_DMA_RX_IRQHandler DMA2_Channel2_IRQHandler
  134. #define UART5_RX_DMA_RCC RCC_AHB1ENR_DMA2EN
  135. #define UART5_RX_DMA_INSTANCE DMA2_Channel2
  136. #if defined(DMAMUX1) /* for L4+ */
  137. #define UART5_RX_DMA_REQUEST DMA_REQUEST_UART5_RX
  138. #else /* for L4 */
  139. #define UART5_RX_DMA_REQUEST DMA_REQUEST_2
  140. #endif /* DMAMUX1 */
  141. #define UART5_RX_DMA_IRQ DMA2_Channel2_IRQn
  142. #endif
  143. /* DMA2 channel3 */
  144. #if defined(BSP_SPI1_RX_USING_DMA) && !defined(SPI1_RX_DMA_INSTANCE)
  145. #define SPI1_DMA_RX_IRQHandler DMA2_Channel3_IRQHandler
  146. #define SPI1_RX_DMA_RCC RCC_AHB1ENR_DMA2EN
  147. #define SPI1_RX_DMA_INSTANCE DMA2_Channel3
  148. #if defined(DMAMUX1) /* for L4+ */
  149. #define SPI1_RX_DMA_REQUEST DMA_REQUEST_SPI1_RX
  150. #else /* for L4 */
  151. #define SPI1_RX_DMA_REQUEST DMA_REQUEST_4
  152. #endif /* DMAMUX1 */
  153. #define SPI1_RX_DMA_IRQ DMA2_Channel3_IRQn
  154. #endif
  155. /* DMA2 channel4 */
  156. #if defined(BSP_SPI1_TX_USING_DMA) && !defined(SPI1_TX_DMA_INSTANCE)
  157. #define SPI1_DMA_TX_IRQHandler DMA2_Channel4_IRQHandler
  158. #define SPI1_TX_DMA_RCC RCC_AHB1ENR_DMA2EN
  159. #define SPI1_TX_DMA_INSTANCE DMA2_Channel4
  160. #if defined(DMAMUX1) /* for L4+ */
  161. #define SPI1_TX_DMA_REQUEST DMA_REQUEST_SPI1_TX
  162. #else /* for L4 */
  163. #define SPI1_TX_DMA_REQUEST DMA_REQUEST_4
  164. #endif /* DMAMUX1 */
  165. #define SPI1_TX_DMA_IRQ DMA2_Channel4_IRQn
  166. #endif
  167. /* DMA2 channel5 */
  168. /* DMA2 channel6 */
  169. #if defined(BSP_UART1_TX_USING_DMA) && !defined(UART1_TX_DMA_INSTANCE)
  170. #define UART1_DMA_TX_IRQHandler DMA2_Channel6_IRQHandler
  171. #define UART1_TX_DMA_RCC RCC_AHB1ENR_DMA2EN
  172. #define UART1_TX_DMA_INSTANCE DMA2_Channel6
  173. #if defined(DMAMUX1) /* for L4+ */
  174. #define UART1_TX_DMA_REQUEST DMA_REQUEST_USART1_TX
  175. #else /* for L4 */
  176. #define UART1_TX_DMA_REQUEST DMA_REQUEST_2
  177. #endif /* DMAMUX1 */
  178. #define UART1_TX_DMA_IRQ DMA2_Channel6_IRQn
  179. #endif
  180. /* DMA2 channel7 */
  181. #if defined(BSP_UART1_RX_USING_DMA) && !defined(UART1_RX_DMA_INSTANCE)
  182. #define UART1_DMA_RX_IRQHandler DMA2_Channel7_IRQHandler
  183. #define UART1_RX_DMA_RCC RCC_AHB1ENR_DMA2EN
  184. #define UART1_RX_DMA_INSTANCE DMA2_Channel7
  185. #if defined(DMAMUX1) /* for L4+ */
  186. #define UART1_RX_DMA_REQUEST DMA_REQUEST_USART1_RX
  187. #else /* for L4 */
  188. #define UART1_RX_DMA_REQUEST DMA_REQUEST_2
  189. #endif /* DMAMUX1 */
  190. #define UART1_RX_DMA_IRQ DMA2_Channel7_IRQn
  191. #elif defined(BSP_QSPI_USING_DMA) && !defined(QSPI_DMA_INSTANCE)
  192. #define QSPI_DMA_IRQHandler DMA2_Channel7_IRQHandler
  193. #define QSPI_DMA_RCC RCC_AHB1ENR_DMA2EN
  194. #define QSPI_DMA_INSTANCE DMA2_Channel7
  195. #if defined(DMAMUX1) /* for L4+ */
  196. #define QSPI_DMA_REQUEST DMA_REQUEST_OCTOSPI1
  197. #else /* for L4 */
  198. #define QSPI_DMA_REQUEST DMA_REQUEST_3
  199. #endif /* DMAMUX1 */
  200. #define QSPI_DMA_IRQ DMA2_Channel7_IRQn
  201. #elif defined(BSP_LPUART1_RX_USING_DMA) && !defined(LPUART1_RX_DMA_INSTANCE)
  202. #define LPUART1_DMA_RX_IRQHandler DMA2_Channel7_IRQHandler
  203. #define LPUART1_RX_DMA_RCC RCC_AHB1ENR_DMA2EN
  204. #define LPUART1_RX_DMA_INSTANCE DMA2_Channel7
  205. #if defined(DMAMUX1) /* for L4+ */
  206. #define LPUART1_RX_DMA_REQUEST DMA_REQUEST_LPUART1_RX
  207. #else /* for L4 */
  208. #define LPUART1_RX_DMA_REQUEST DMA_REQUEST_4
  209. #endif /* DMAMUX1 */
  210. #define LPUART1_RX_DMA_IRQ DMA2_Channel7_IRQn
  211. #endif
  212. #ifdef __cplusplus
  213. }
  214. #endif
  215. #endif /* __DMA_CONFIG_H__ */