dma_config.h 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  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. * 2023-01-31 shelton first version
  9. */
  10. #ifndef __DMA_CONFIG_H__
  11. #define __DMA_CONFIG_H__
  12. #include <rtthread.h>
  13. #ifdef __cplusplus
  14. extern "C" {
  15. #endif
  16. /* DMA1 channel1 */
  17. /* DMA1 channel2 */
  18. #if defined(BSP_SPI1_RX_USING_DMA) && !defined(SPI1_RX_DMA_CHANNEL)
  19. #define SPI1_TX_RX_DMA_IRQHandler DMA1_Channel3_2_IRQHandler
  20. #define SPI1_RX_DMA_CLOCK CRM_DMA1_PERIPH_CLOCK
  21. #define SPI1_RX_DMA_CHANNEL DMA1_CHANNEL2
  22. #define SPI1_RX_DMA_IRQ DMA1_Channel3_2_IRQn
  23. #define SPI1_RX_DMA_FLEX_CHANNEL FLEX_CHANNEL2
  24. #define SPI1_RX_DMA_REQ_ID DMA_FLEXIBLE_SPI1_RX
  25. #elif defined(BSP_UART1_RX_USING_DMA) && !defined(UART1_RX_DMA_CHANNEL)
  26. #define UART1_TX_RX_DMA_IRQHandler DMA1_Channel3_2_IRQHandler
  27. #define UART1_RX_DMA_CLOCK CRM_DMA1_PERIPH_CLOCK
  28. #define UART1_RX_DMA_CHANNEL DMA1_CHANNEL2
  29. #define UART1_RX_DMA_IRQ DMA1_Channel3_2_IRQn
  30. #define UART1_RX_DMA_FLEX_CHANNEL FLEX_CHANNEL2
  31. #define UART1_RX_DMA_REQ_ID DMA_FLEXIBLE_UART1_RX
  32. #elif defined(BSP_I2C1_RX_USING_DMA) && !defined(I2C1_RX_DMA_CHANNEL)
  33. #define I2C1_TX_RX_DMA_IRQHandler DMA1_Channel3_2_IRQHandler
  34. #define I2C1_RX_DMA_CLOCK CRM_DMA1_PERIPH_CLOCK
  35. #define I2C1_RX_DMA_CHANNEL DMA1_CHANNEL2
  36. #define I2C1_RX_DMA_IRQ DMA1_Channel3_2_IRQn
  37. #define I2C1_RX_DMA_FLEX_CHANNEL FLEX_CHANNEL2
  38. #define I2C1_RX_DMA_REQ_ID DMA_FLEXIBLE_I2C1_RX
  39. #endif
  40. /* DMA1 channel3 */
  41. #if defined(BSP_SPI1_TX_USING_DMA) && !defined(SPI1_TX_DMA_CHANNEL)
  42. #define SPI1_TX_RX_DMA_IRQHandler DMA1_Channel3_2_IRQHandler
  43. #define SPI1_TX_DMA_CLOCK CRM_DMA1_PERIPH_CLOCK
  44. #define SPI1_TX_DMA_CHANNEL DMA1_CHANNEL3
  45. #define SPI1_TX_DMA_IRQ DMA1_Channel3_2_IRQn
  46. #define SPI1_TX_DMA_FLEX_CHANNEL FLEX_CHANNEL3
  47. #define SPI1_TX_DMA_REQ_ID DMA_FLEXIBLE_SPI1_TX
  48. #elif defined(BSP_UART1_TX_USING_DMA) && !defined(UART1_TX_DMA_CHANNEL)
  49. #define UART1_TX_RX_DMA_IRQHandler DMA1_Channel3_2_IRQHandler
  50. #define UART1_TX_DMA_CLOCK CRM_DMA1_PERIPH_CLOCK
  51. #define UART1_TX_DMA_CHANNEL DMA1_CHANNEL3
  52. #define UART1_TX_DMA_IRQ DMA1_Channel3_2_IRQn
  53. #define UART1_TX_DMA_FLEX_CHANNEL FLEX_CHANNEL3
  54. #define UART1_TX_DMA_REQ_ID DMA_FLEXIBLE_UART1_TX
  55. #elif defined(BSP_I2C1_TX_USING_DMA) && !defined(I2C1_TX_DMA_CHANNEL)
  56. #define I2C1_TX_RX_DMA_IRQHandler DMA1_Channel3_2_IRQHandler
  57. #define I2C1_TX_DMA_CLOCK CRM_DMA1_PERIPH_CLOCK
  58. #define I2C1_TX_DMA_CHANNEL DMA1_CHANNEL3
  59. #define I2C1_TX_DMA_IRQ DMA1_Channel3_2_IRQn
  60. #define I2C1_TX_DMA_FLEX_CHANNEL FLEX_CHANNEL3
  61. #define I2C1_TX_DMA_REQ_ID DMA_FLEXIBLE_I2C1_TX
  62. #endif
  63. /* DMA1 channel4 */
  64. #if defined(BSP_SPI2_RX_USING_DMA) && !defined(SPI2_RX_DMA_CHANNEL)
  65. #define SPI3_2_TX_RX_DMA_IRQHandler DMA1_Channel7_4_IRQHandler
  66. #define SPI2_RX_DMA_CLOCK CRM_DMA1_PERIPH_CLOCK
  67. #define SPI2_RX_DMA_CHANNEL DMA1_CHANNEL4
  68. #define SPI2_RX_DMA_IRQ DMA1_Channel7_4_IRQn
  69. #define SPI2_RX_DMA_FLEX_CHANNEL FLEX_CHANNEL4
  70. #define SPI2_RX_DMA_REQ_ID DMA_FLEXIBLE_SPI2_RX
  71. #elif defined(BSP_UART2_RX_USING_DMA) && !defined(UART2_RX_DMA_CHANNEL)
  72. #define UART3_2_TX_RX_DMA_IRQHandler DMA1_Channel7_4_IRQHandler
  73. #define UART2_RX_DMA_CLOCK CRM_DMA1_PERIPH_CLOCK
  74. #define UART2_RX_DMA_CHANNEL DMA1_CHANNEL4
  75. #define UART2_RX_DMA_IRQ DMA1_Channel7_4_IRQn
  76. #define UART2_RX_DMA_FLEX_CHANNEL FLEX_CHANNEL4
  77. #define UART2_RX_DMA_REQ_ID DMA_FLEXIBLE_UART2_RX
  78. #elif defined(BSP_I2C2_RX_USING_DMA) && !defined(I2C2_RX_DMA_CHANNEL)
  79. #define I2C2_TX_RX_DMA_IRQHandler DMA1_Channel7_4_IRQHandler
  80. #define I2C2_RX_DMA_CLOCK CRM_DMA1_PERIPH_CLOCK
  81. #define I2C2_RX_DMA_CHANNEL DMA1_CHANNEL4
  82. #define I2C2_RX_DMA_IRQ DMA1_Channel7_4_IRQn
  83. #define I2C2_RX_DMA_FLEX_CHANNEL FLEX_CHANNEL4
  84. #define I2C2_RX_DMA_REQ_ID DMA_FLEXIBLE_I2C2_RX
  85. #endif
  86. /* DMA1 channel5 */
  87. #if defined(BSP_SPI2_TX_USING_DMA) && !defined(SPI2_TX_DMA_CHANNEL)
  88. #define SPI3_2_TX_RX_DMA_IRQHandler DMA1_Channel7_4_IRQHandler
  89. #define SPI2_TX_DMA_CLOCK CRM_DMA1_PERIPH_CLOCK
  90. #define SPI2_TX_DMA_CHANNEL DMA1_CHANNEL5
  91. #define SPI2_TX_DMA_IRQ DMA1_Channel7_4_IRQn
  92. #define SPI2_TX_DMA_FLEX_CHANNEL FLEX_CHANNEL5
  93. #define SPI2_TX_DMA_REQ_ID DMA_FLEXIBLE_SPI2_TX
  94. #elif defined(BSP_UART2_TX_USING_DMA) && !defined(UART2_TX_DMA_CHANNEL)
  95. #define UART3_2_TX_RX_DMA_IRQHandler DMA1_Channel7_4_IRQHandler
  96. #define UART2_TX_DMA_CLOCK CRM_DMA1_PERIPH_CLOCK
  97. #define UART2_TX_DMA_CHANNEL DMA1_CHANNEL5
  98. #define UART2_TX_DMA_IRQ DMA1_Channel7_4_IRQn
  99. #define UART2_TX_DMA_FLEX_CHANNEL FLEX_CHANNEL5
  100. #define UART2_TX_DMA_REQ_ID DMA_FLEXIBLE_UART2_TX
  101. #elif defined(BSP_I2C2_TX_USING_DMA) && !defined(I2C2_TX_DMA_CHANNEL)
  102. #define I2C2_TX_RX_DMA_IRQHandler DMA1_Channel7_4_IRQHandler
  103. #define I2C2_TX_DMA_CLOCK CRM_DMA1_PERIPH_CLOCK
  104. #define I2C2_TX_DMA_CHANNEL DMA1_CHANNEL5
  105. #define I2C2_TX_DMA_IRQ DMA1_Channel7_4_IRQn
  106. #define I2C2_TX_DMA_FLEX_CHANNEL FLEX_CHANNEL5
  107. #define I2C2_TX_DMA_REQ_ID DMA_FLEXIBLE_I2C2_TX
  108. #endif
  109. /* DMA1 channel6 */
  110. #if defined(BSP_SPI3_RX_USING_DMA) && !defined(SPI3_RX_DMA_CHANNEL)
  111. #define SPI3_2_TX_RX_DMA_IRQHandler DMA1_Channel7_4_IRQHandler
  112. #define SPI3_RX_DMA_CLOCK CRM_DMA1_PERIPH_CLOCK
  113. #define SPI3_RX_DMA_CHANNEL DMA1_CHANNEL6
  114. #define SPI3_RX_DMA_IRQ DMA1_Channel7_4_IRQn
  115. #define SPI3_RX_DMA_FLEX_CHANNEL FLEX_CHANNEL6
  116. #define SPI3_RX_DMA_REQ_ID DMA_FLEXIBLE_SPI3_RX
  117. #elif defined(BSP_UART3_RX_USING_DMA) && !defined(UART3_RX_DMA_CHANNEL)
  118. #define UART3_2_TX_RX_DMA_IRQHandler DMA1_Channel7_4_IRQHandler
  119. #define UART3_RX_DMA_CLOCK CRM_DMA1_PERIPH_CLOCK
  120. #define UART3_RX_DMA_CHANNEL DMA1_CHANNEL6
  121. #define UART3_RX_DMA_IRQ DMA1_Channel7_4_IRQn
  122. #define UART3_RX_DMA_FLEX_CHANNEL FLEX_CHANNEL6
  123. #define UART3_RX_DMA_REQ_ID DMA_FLEXIBLE_UART3_RX
  124. #endif
  125. /* DMA1 channel7 */
  126. #if defined(BSP_SPI3_TX_USING_DMA) && !defined(SPI3_TX_DMA_CHANNEL)
  127. #define SPI3_2_TX_RX_DMA_IRQHandler DMA1_Channel7_4_IRQHandler
  128. #define SPI3_TX_DMA_CLOCK CRM_DMA1_PERIPH_CLOCK
  129. #define SPI3_TX_DMA_CHANNEL DMA1_CHANNEL7
  130. #define SPI3_TX_DMA_IRQ DMA1_Channel7_4_IRQn
  131. #define SPI3_TX_DMA_FLEX_CHANNEL FLEX_CHANNEL7
  132. #define SPI3_TX_DMA_REQ_ID DMA_FLEXIBLE_SPI3_TX
  133. #elif defined(BSP_UART3_TX_USING_DMA) && !defined(UART3_TX_DMA_CHANNEL)
  134. #define UART3_2_TX_RX_DMA_IRQHandler DMA1_Channel7_4_IRQHandler
  135. #define UART3_TX_DMA_CLOCK CRM_DMA1_PERIPH_CLOCK
  136. #define UART3_TX_DMA_CHANNEL DMA1_CHANNEL7
  137. #define UART3_TX_DMA_IRQ DMA1_Channel7_4_IRQn
  138. #define UART3_TX_DMA_FLEX_CHANNEL FLEX_CHANNEL7
  139. #define UART3_TX_DMA_REQ_ID DMA_FLEXIBLE_UART3_TX
  140. #endif
  141. #ifdef __cplusplus
  142. }
  143. #endif
  144. #endif /* __DMA_CONFIG_H__ */