dma_config.h 9.1 KB
Newer Older
1
/*
mysterywolf's avatar
mysterywolf 已提交
2
 * Copyright (c) 2006-2021, RT-Thread Development Team
3 4 5 6 7
 *
 * SPDX-License-Identifier: Apache-2.0
 *
 * Change Logs:
 * Date           Author       Notes
8 9
 * 2019-01-05     zylx         first version
 * 2019-01-08     SummerGift   clean up the code
10
 * 2019-12-01     armink       add DMAMUX support
11 12 13 14 15 16 17
 */

#ifndef __DMA_CONFIG_H__
#define __DMA_CONFIG_H__

#include <rtthread.h>

18 19 20 21
#ifdef __cplusplus
extern "C" {
#endif

22
/* DMA1 channel1 */
23

24 25
/* DMA1 channel2 */
#if defined(BSP_SPI1_RX_USING_DMA) && !defined(SPI1_RX_DMA_INSTANCE)
26 27 28
#define SPI1_DMA_RX_IRQHandler          DMA1_Channel2_IRQHandler
#define SPI1_RX_DMA_RCC                 RCC_AHB1ENR_DMA1EN
#define SPI1_RX_DMA_INSTANCE            DMA1_Channel2
29 30 31
#if defined(DMAMUX1) /* for L4+ */
#define SPI1_RX_DMA_REQUEST             DMA_REQUEST_SPI1_RX
#else /* for L4 */
32
#define SPI1_RX_DMA_REQUEST             DMA_REQUEST_1
33
#endif /* DMAMUX1 */
34 35 36
#define SPI1_RX_DMA_IRQ                 DMA1_Channel2_IRQn
#endif

37 38
/* DMA1 channel3 */
#if defined(BSP_SPI1_TX_USING_DMA) && !defined(SPI1_TX_DMA_INSTANCE)
39 40 41
#define SPI1_DMA_TX_IRQHandler          DMA1_Channel3_IRQHandler
#define SPI1_TX_DMA_RCC                 RCC_AHB1ENR_DMA1EN
#define SPI1_TX_DMA_INSTANCE            DMA1_Channel3
42 43 44
#if defined(DMAMUX1) /* for L4+ */
#define SPI1_TX_DMA_REQUEST             DMA_REQUEST_SPI1_TX
#else /* for L4 */
45
#define SPI1_TX_DMA_REQUEST             DMA_REQUEST_1
46
#endif /* DMAMUX1 */
47
#define SPI1_TX_DMA_IRQ                 DMA1_Channel3_IRQn
48 49 50 51
#elif defined(BSP_UART3_RX_USING_DMA) && !defined(UART3_RX_DMA_INSTANCE)
#define UART3_DMA_RX_IRQHandler         DMA1_Channel3_IRQHandler
#define UART3_RX_DMA_RCC                RCC_AHB1ENR_DMA1EN
#define UART3_RX_DMA_INSTANCE           DMA1_Channel3
52 53 54
#if defined(DMAMUX1) /* for L4+ */
#define UART3_RX_DMA_REQUEST            DMA_REQUEST_USART3_RX
#else /* for L4 */
55
#define UART3_RX_DMA_REQUEST            DMA_REQUEST_2
56
#endif /* DMAMUX1 */
57
#define UART3_RX_DMA_IRQ                DMA1_Channel3_IRQn
58 59
#endif

60 61 62 63 64
/* DMA1 channel4 */
#if defined(BSP_UART1_TX_USING_DMA) && !defined(UART1_TX_DMA_INSTANCE)
#define UART1_DMA_TX_IRQHandler         DMA1_Channel4_IRQHandler
#define UART1_TX_DMA_RCC                RCC_AHB1ENR_DMA1EN
#define UART1_TX_DMA_INSTANCE           DMA1_Channel4
65 66 67
#if defined(DMAMUX1) /* for L4+ */
#define UART1_TX_DMA_REQUEST            DMA_REQUEST_USART1_TX
#else /* for L4 */
68
#define UART1_TX_DMA_REQUEST            DMA_REQUEST_2
69
#endif /* DMAMUX1 */
70
#define UART1_TX_DMA_IRQ                DMA1_Channel4_IRQn
71 72 73 74
#elif defined(BSP_SPI2_RX_USING_DMA) && !defined(SPI2_RX_DMA_INSTANCE)
#define SPI2_DMA_RX_IRQHandler          DMA1_Channel4_IRQHandler
#define SPI2_RX_DMA_RCC                 RCC_AHB1ENR_DMA1EN
#define SPI2_RX_DMA_INSTANCE            DMA1_Channel4
75 76 77
#if defined(DMAMUX1) /* for L4+ */
#define SPI2_RX_DMA_REQUEST             DMA_REQUEST_SPI2_RX
#else /* for L4 */
78
#define SPI2_RX_DMA_REQUEST             DMA_REQUEST_1
79
#endif /* DMAMUX1 */
80
#define SPI2_RX_DMA_IRQ                 DMA1_Channel4_IRQn
81 82
#endif

83 84 85 86 87
/* DMA1 channel5 */
#if defined(BSP_UART1_RX_USING_DMA) && !defined(UART1_RX_DMA_INSTANCE)
#define UART1_DMA_RX_IRQHandler         DMA1_Channel5_IRQHandler
#define UART1_RX_DMA_RCC                RCC_AHB1ENR_DMA1EN
#define UART1_RX_DMA_INSTANCE           DMA1_Channel5
88 89 90
#if defined(DMAMUX1) /* for L4+ */
#define UART1_RX_DMA_REQUEST            DMA_REQUEST_USART1_RX
#else /* for L4 */
91
#define UART1_RX_DMA_REQUEST            DMA_REQUEST_2
92
#endif /* DMAMUX1 */
93 94
#define UART1_RX_DMA_IRQ                DMA1_Channel5_IRQn
#elif defined(BSP_QSPI_USING_DMA) && !defined(QSPI_DMA_INSTANCE)
95 96 97
#define QSPI_DMA_IRQHandler             DMA1_Channel5_IRQHandler
#define QSPI_DMA_RCC                    RCC_AHB1ENR_DMA1EN
#define QSPI_DMA_INSTANCE               DMA1_Channel5
98 99 100
#if defined(DMAMUX1) /* for L4+ */
#define QSPI_DMA_REQUEST                DMA_REQUEST_OCTOSPI1
#else /* for L4 */
101
#define QSPI_DMA_REQUEST                DMA_REQUEST_5
102
#endif /* DMAMUX1 */
103
#define QSPI_DMA_IRQ                    DMA1_Channel5_IRQn
104 105 106 107
#elif defined(BSP_SPI2_TX_USING_DMA) && !defined(SPI2_TX_DMA_INSTANCE)
#define SPI2_DMA_TX_IRQHandler          DMA1_Channel5_IRQHandler
#define SPI2_TX_DMA_RCC                 RCC_AHB1ENR_DMA1EN
#define SPI2_TX_DMA_INSTANCE            DMA1_Channel5
108 109 110
#if defined(DMAMUX1) /* for L4+ */
#define SPI2_TX_DMA_REQUEST             DMA_REQUEST_SPI2_TX
#else /* for L4 */
111
#define SPI2_TX_DMA_REQUEST             DMA_REQUEST_1
112
#endif /* DMAMUX1 */
113
#define SPI2_TX_DMA_IRQ                 DMA1_Channel5_IRQn
114 115
#endif

116
/* DMA1 channel6 */
117 118 119 120
#if defined(BSP_UART2_RX_USING_DMA) && !defined(UART2_RX_DMA_INSTANCE)
#define UART2_DMA_RX_IRQHandler         DMA1_Channel6_IRQHandler
#define UART2_RX_DMA_RCC                RCC_AHB1ENR_DMA1EN
#define UART2_RX_DMA_INSTANCE           DMA1_Channel6
121 122 123
#if defined(DMAMUX1) /* for L4+ */
#define UART2_RX_DMA_REQUEST            DMA_REQUEST_USART2_RX
#else /* for L4 */
124
#define UART2_RX_DMA_REQUEST            DMA_REQUEST_2
125
#endif /* DMAMUX1 */
126 127
#define UART2_RX_DMA_IRQ                DMA1_Channel6_IRQn
#endif
128

129
/* DMA1 channel7 */
130

131 132
/* DMA2 channel1 */
#if defined(BSP_UART5_TX_USING_DMA) && !defined(UART5_TX_DMA_INSTANCE)
133 134 135
#define UART5_DMA_TX_IRQHandler         DMA2_Channel1_IRQHandler
#define UART5_TX_DMA_RCC                RCC_AHB1ENR_DMA2EN
#define UART5_TX_DMA_INSTANCE           DMA2_Channel1
136 137 138
#if defined(DMAMUX1) /* for L4+ */
#define UART5_TX_DMA_REQUEST            DMA_REQUEST_UART5_TX
#else /* for L4 */
139
#define UART5_TX_DMA_REQUEST            DMA_REQUEST_2
140
#endif /* DMAMUX1 */
141 142 143
#define UART5_TX_DMA_IRQ                DMA2_Channel1_IRQn
#endif

144 145
/* DMA2 channel2 */
#if defined(BSP_UART5_RX_USING_DMA) && !defined(UART5_RX_DMA_INSTANCE)
146 147 148
#define UART5_DMA_RX_IRQHandler         DMA2_Channel2_IRQHandler
#define UART5_RX_DMA_RCC                RCC_AHB1ENR_DMA2EN
#define UART5_RX_DMA_INSTANCE           DMA2_Channel2
149 150 151
#if defined(DMAMUX1) /* for L4+ */
#define UART5_RX_DMA_REQUEST            DMA_REQUEST_UART5_RX
#else /* for L4 */
152
#define UART5_RX_DMA_REQUEST            DMA_REQUEST_2
153
#endif /* DMAMUX1 */
154 155 156
#define UART5_RX_DMA_IRQ                DMA2_Channel2_IRQn
#endif

157 158
/* DMA2 channel3 */
#if defined(BSP_SPI1_RX_USING_DMA) && !defined(SPI1_RX_DMA_INSTANCE)
159 160 161
#define SPI1_DMA_RX_IRQHandler          DMA2_Channel3_IRQHandler
#define SPI1_RX_DMA_RCC                 RCC_AHB1ENR_DMA2EN
#define SPI1_RX_DMA_INSTANCE            DMA2_Channel3
162 163 164
#if defined(DMAMUX1) /* for L4+ */
#define SPI1_RX_DMA_REQUEST             DMA_REQUEST_SPI1_RX
#else /* for L4 */
165
#define SPI1_RX_DMA_REQUEST             DMA_REQUEST_4
166
#endif /* DMAMUX1 */
167 168 169
#define SPI1_RX_DMA_IRQ                 DMA2_Channel3_IRQn
#endif

170 171
/* DMA2 channel4 */
#if defined(BSP_SPI1_TX_USING_DMA) && !defined(SPI1_TX_DMA_INSTANCE)
172 173 174
#define SPI1_DMA_TX_IRQHandler          DMA2_Channel4_IRQHandler
#define SPI1_TX_DMA_RCC                 RCC_AHB1ENR_DMA2EN
#define SPI1_TX_DMA_INSTANCE            DMA2_Channel4
175 176 177
#if defined(DMAMUX1) /* for L4+ */
#define SPI1_TX_DMA_REQUEST             DMA_REQUEST_SPI1_TX
#else /* for L4 */
178
#define SPI1_TX_DMA_REQUEST             DMA_REQUEST_4
179
#endif /* DMAMUX1 */
180 181 182
#define SPI1_TX_DMA_IRQ                 DMA2_Channel4_IRQn
#endif

183
/* DMA2 channel5 */
184

185 186 187 188 189
/* DMA2 channel6 */
#if defined(BSP_UART1_TX_USING_DMA) && !defined(UART1_TX_DMA_INSTANCE)
#define UART1_DMA_TX_IRQHandler         DMA2_Channel6_IRQHandler
#define UART1_TX_DMA_RCC                RCC_AHB1ENR_DMA2EN
#define UART1_TX_DMA_INSTANCE           DMA2_Channel6
190 191 192
#if defined(DMAMUX1) /* for L4+ */
#define UART1_TX_DMA_REQUEST            DMA_REQUEST_USART1_TX
#else /* for L4 */
193
#define UART1_TX_DMA_REQUEST            DMA_REQUEST_2
194
#endif /* DMAMUX1 */
195
#define UART1_TX_DMA_IRQ                DMA2_Channel6_IRQn
196 197
#endif

198 199 200 201 202
/* DMA2 channel7 */
#if defined(BSP_UART1_RX_USING_DMA) && !defined(UART1_RX_DMA_INSTANCE)
#define UART1_DMA_RX_IRQHandler         DMA2_Channel7_IRQHandler
#define UART1_RX_DMA_RCC                RCC_AHB1ENR_DMA2EN
#define UART1_RX_DMA_INSTANCE           DMA2_Channel7
203 204 205
#if defined(DMAMUX1) /* for L4+ */
#define UART1_RX_DMA_REQUEST            DMA_REQUEST_USART1_RX
#else /* for L4 */
206
#define UART1_RX_DMA_REQUEST            DMA_REQUEST_2
207
#endif /* DMAMUX1 */
208 209
#define UART1_RX_DMA_IRQ                DMA2_Channel7_IRQn
#elif defined(BSP_QSPI_USING_DMA) && !defined(QSPI_DMA_INSTANCE)
210 211 212
#define QSPI_DMA_IRQHandler             DMA2_Channel7_IRQHandler
#define QSPI_DMA_RCC                    RCC_AHB1ENR_DMA2EN
#define QSPI_DMA_INSTANCE               DMA2_Channel7
213 214 215
#if defined(DMAMUX1) /* for L4+ */
#define QSPI_DMA_REQUEST                DMA_REQUEST_OCTOSPI1
#else /* for L4 */
216
#define QSPI_DMA_REQUEST                DMA_REQUEST_3
217
#endif /* DMAMUX1 */
218
#define QSPI_DMA_IRQ                    DMA2_Channel7_IRQn
219 220 221 222
#elif defined(BSP_LPUART1_RX_USING_DMA) && !defined(LPUART1_RX_DMA_INSTANCE)
#define LPUART1_DMA_RX_IRQHandler       DMA2_Channel7_IRQHandler
#define LPUART1_RX_DMA_RCC              RCC_AHB1ENR_DMA2EN
#define LPUART1_RX_DMA_INSTANCE         DMA2_Channel7
223 224 225
#if defined(DMAMUX1) /* for L4+ */
#define LPUART1_RX_DMA_REQUEST          DMA_REQUEST_LPUART1_RX
#else /* for L4 */
226
#define LPUART1_RX_DMA_REQUEST          DMA_REQUEST_4
227
#endif /* DMAMUX1 */
228
#define LPUART1_RX_DMA_IRQ              DMA2_Channel7_IRQn
229 230
#endif

231 232 233 234
#ifdef __cplusplus
}
#endif

235
#endif /* __DMA_CONFIG_H__ */