spi_config.h 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. /*
  2. * Copyright (c) 2006-2018, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2018-11-06 SummerGift change to new framework
  9. */
  10. #ifndef __SPI_CONFIG_H__
  11. #define __SPI_CONFIG_H__
  12. #include <rtthread.h>
  13. #ifdef BSP_USING_SPI1
  14. #ifndef SPI1_BUS_CONFIG
  15. #define SPI1_BUS_CONFIG \
  16. { \
  17. .Instance = SPI1, \
  18. .bus_name = "spi1", \
  19. }
  20. #endif /* SPI1_BUS_CONFIG */
  21. #endif /* BSP_USING_SPI1 */
  22. #ifdef BSP_SPI1_TX_USING_DMA
  23. #ifndef SPI1_TX_DMA_CONFIG
  24. #define SPI1_TX_DMA_CONFIG \
  25. { \
  26. .dma_rcc = SPI1_TX_DMA_RCC, \
  27. .Instance = SPI1_TX_DMA_INSTANCE, \
  28. .channel = SPI1_TX_DMA_CHANNEL, \
  29. .dma_irq = SPI1_TX_DMA_IRQ, \
  30. }
  31. #endif /* SPI1_TX_DMA_CONFIG */
  32. #endif /* BSP_SPI1_TX_USING_DMA */
  33. #ifdef BSP_SPI1_RX_USING_DMA
  34. #ifndef SPI1_RX_DMA_CONFIG
  35. #define SPI1_RX_DMA_CONFIG \
  36. { \
  37. .dma_rcc = SPI1_RX_DMA_RCC, \
  38. .Instance = SPI1_RX_DMA_INSTANCE, \
  39. .channel = SPI1_RX_DMA_CHANNEL, \
  40. .dma_irq = SPI1_RX_DMA_IRQ, \
  41. }
  42. #endif /* SPI1_RX_DMA_CONFIG */
  43. #endif /* BSP_SPI1_RX_USING_DMA */
  44. #ifdef BSP_USING_SPI2
  45. #ifndef SPI2_BUS_CONFIG
  46. #define SPI2_BUS_CONFIG \
  47. { \
  48. .Instance = SPI2, \
  49. .bus_name = "spi2", \
  50. }
  51. #endif /* SPI2_BUS_CONFIG */
  52. #endif /* BSP_USING_SPI2 */
  53. #ifdef BSP_SPI2_TX_USING_DMA
  54. #ifndef SPI2_TX_DMA_CONFIG
  55. #define SPI2_TX_DMA_CONFIG \
  56. { \
  57. .dma_rcc = SPI2_TX_DMA_RCC, \
  58. .Instance = SPI2_TX_DMA_INSTANCE, \
  59. .channel = SPI2_TX_DMA_CHANNEL, \
  60. .dma_irq = SPI2_TX_DMA_IRQ, \
  61. }
  62. #endif /* SPI2_TX_DMA_CONFIG */
  63. #endif /* BSP_SPI2_TX_USING_DMA */
  64. #ifdef BSP_SPI2_RX_USING_DMA
  65. #ifndef SPI2_RX_DMA_CONFIG
  66. #define SPI2_RX_DMA_CONFIG \
  67. { \
  68. .dma_rcc = SPI2_RX_DMA_RCC, \
  69. .Instance = SPI2_RX_DMA_INSTANCE, \
  70. .channel = SPI2_RX_DMA_CHANNEL, \
  71. .dma_irq = SPI2_RX_DMA_IRQ, \
  72. }
  73. #endif /* SPI2_RX_DMA_CONFIG */
  74. #endif /* BSP_SPI2_RX_USING_DMA */
  75. #ifdef BSP_USING_SPI3
  76. #ifndef SPI3_BUS_CONFIG
  77. #define SPI3_BUS_CONFIG \
  78. { \
  79. .Instance = SPI3, \
  80. .bus_name = "spi3", \
  81. }
  82. #endif /* SPI3_BUS_CONFIG */
  83. #endif /* BSP_USING_SPI3 */
  84. #ifdef BSP_SPI3_TX_USING_DMA
  85. #ifndef SPI3_TX_DMA_CONFIG
  86. #define SPI3_TX_DMA_CONFIG \
  87. { \
  88. .dma_rcc = SPI3_TX_DMA_RCC, \
  89. .Instance = SPI3_TX_DMA_INSTANCE, \
  90. .channel = SPI3_TX_DMA_CHANNEL, \
  91. .dma_irq = SPI3_TX_DMA_IRQ, \
  92. }
  93. #endif /* SPI3_TX_DMA_CONFIG */
  94. #endif /* BSP_SPI3_TX_USING_DMA */
  95. #ifdef BSP_SPI3_RX_USING_DMA
  96. #ifndef SPI3_RX_DMA_CONFIG
  97. #define SPI3_RX_DMA_CONFIG \
  98. { \
  99. .dma_rcc = SPI3_RX_DMA_RCC, \
  100. .Instance = SPI3_RX_DMA_INSTANCE, \
  101. .channel = SPI3_RX_DMA_CHANNEL, \
  102. .dma_irq = SPI3_RX_DMA_IRQ, \
  103. }
  104. #endif /* SPI3_RX_DMA_CONFIG */
  105. #endif /* BSP_SPI3_RX_USING_DMA */
  106. #ifdef BSP_USING_SPI4
  107. #ifndef SPI4_BUS_CONFIG
  108. #define SPI4_BUS_CONFIG \
  109. { \
  110. .Instance = SPI4, \
  111. .bus_name = "spi4", \
  112. }
  113. #endif /* SPI4_BUS_CONFIG */
  114. #endif /* BSP_USING_SPI4 */
  115. #ifdef BSP_SPI4_TX_USING_DMA
  116. #ifndef SPI4_TX_DMA_CONFIG
  117. #define SPI4_TX_DMA_CONFIG \
  118. { \
  119. .dma_rcc = SPI4_TX_DMA_RCC, \
  120. .Instance = SPI4_TX_DMA_INSTANCE, \
  121. .channel = SPI4_TX_DMA_CHANNEL, \
  122. .dma_irq = SPI4_TX_DMA_IRQ, \
  123. }
  124. #endif /* SPI4_TX_DMA_CONFIG */
  125. #endif /* BSP_SPI4_TX_USING_DMA */
  126. #ifdef BSP_SPI4_RX_USING_DMA
  127. #ifndef SPI4_RX_DMA_CONFIG
  128. #define SPI4_RX_DMA_CONFIG \
  129. { \
  130. .dma_rcc = SPI4_RX_DMA_RCC, \
  131. .Instance = SPI4_RX_DMA_INSTANCE, \
  132. .channel = SPI4_RX_DMA_CHANNEL, \
  133. .dma_irq = SPI4_RX_DMA_IRQ, \
  134. }
  135. #endif /* SPI4_RX_DMA_CONFIG */
  136. #endif /* BSP_SPI4_RX_USING_DMA */
  137. #ifdef BSP_USING_SPI5
  138. #ifndef SPI5_BUS_CONFIG
  139. #define SPI5_BUS_CONFIG \
  140. { \
  141. .Instance = SPI5, \
  142. .bus_name = "spi5", \
  143. }
  144. #endif /* SPI5_BUS_CONFIG */
  145. #endif /* BSP_USING_SPI5 */
  146. #ifdef BSP_SPI5_TX_USING_DMA
  147. #ifndef SPI5_TX_DMA_CONFIG
  148. #define SPI5_TX_DMA_CONFIG \
  149. { \
  150. .dma_rcc = SPI5_TX_DMA_RCC, \
  151. .Instance = SPI5_TX_DMA_INSTANCE, \
  152. .channel = SPI5_TX_DMA_CHANNEL, \
  153. .dma_irq = SPI5_TX_DMA_IRQ, \
  154. }
  155. #endif /* SPI5_TX_DMA_CONFIG */
  156. #endif /* BSP_SPI5_TX_USING_DMA */
  157. #ifdef BSP_SPI5_RX_USING_DMA
  158. #ifndef SPI5_RX_DMA_CONFIG
  159. #define SPI5_RX_DMA_CONFIG \
  160. { \
  161. .dma_rcc = SPI5_RX_DMA_RCC, \
  162. .Instance = SPI5_RX_DMA_INSTANCE, \
  163. .channel = SPI5_RX_DMA_CHANNEL, \
  164. .dma_irq = SPI5_RX_DMA_IRQ, \
  165. }
  166. #endif /* SPI5_RX_DMA_CONFIG */
  167. #endif /* BSP_SPI5_RX_USING_DMA */
  168. #endif /*__SPI_CONFIG_H__ */