|
@@ -7,6 +7,7 @@
|
|
* Date Author Notes
|
|
* Date Author Notes
|
|
* 2019-01-05 zylx first version
|
|
* 2019-01-05 zylx first version
|
|
* 2019-01-08 SummerGift clean up the code
|
|
* 2019-01-08 SummerGift clean up the code
|
|
|
|
+ * 2019-12-01 armink add DMAMUX support
|
|
*/
|
|
*/
|
|
|
|
|
|
#ifndef __DMA_CONFIG_H__
|
|
#ifndef __DMA_CONFIG_H__
|
|
@@ -25,7 +26,11 @@ extern "C" {
|
|
#define SPI1_DMA_RX_IRQHandler DMA1_Channel2_IRQHandler
|
|
#define SPI1_DMA_RX_IRQHandler DMA1_Channel2_IRQHandler
|
|
#define SPI1_RX_DMA_RCC RCC_AHB1ENR_DMA1EN
|
|
#define SPI1_RX_DMA_RCC RCC_AHB1ENR_DMA1EN
|
|
#define SPI1_RX_DMA_INSTANCE DMA1_Channel2
|
|
#define SPI1_RX_DMA_INSTANCE DMA1_Channel2
|
|
|
|
+#if defined(DMAMUX1) /* for L4+ */
|
|
|
|
+#define SPI1_RX_DMA_REQUEST DMA_REQUEST_SPI1_RX
|
|
|
|
+#else /* for L4 */
|
|
#define SPI1_RX_DMA_REQUEST DMA_REQUEST_1
|
|
#define SPI1_RX_DMA_REQUEST DMA_REQUEST_1
|
|
|
|
+#endif /* DMAMUX1 */
|
|
#define SPI1_RX_DMA_IRQ DMA1_Channel2_IRQn
|
|
#define SPI1_RX_DMA_IRQ DMA1_Channel2_IRQn
|
|
#endif
|
|
#endif
|
|
|
|
|
|
@@ -34,13 +39,21 @@ extern "C" {
|
|
#define SPI1_DMA_TX_IRQHandler DMA1_Channel3_IRQHandler
|
|
#define SPI1_DMA_TX_IRQHandler DMA1_Channel3_IRQHandler
|
|
#define SPI1_TX_DMA_RCC RCC_AHB1ENR_DMA1EN
|
|
#define SPI1_TX_DMA_RCC RCC_AHB1ENR_DMA1EN
|
|
#define SPI1_TX_DMA_INSTANCE DMA1_Channel3
|
|
#define SPI1_TX_DMA_INSTANCE DMA1_Channel3
|
|
|
|
+#if defined(DMAMUX1) /* for L4+ */
|
|
|
|
+#define SPI1_TX_DMA_REQUEST DMA_REQUEST_SPI1_TX
|
|
|
|
+#else /* for L4 */
|
|
#define SPI1_TX_DMA_REQUEST DMA_REQUEST_1
|
|
#define SPI1_TX_DMA_REQUEST DMA_REQUEST_1
|
|
|
|
+#endif /* DMAMUX1 */
|
|
#define SPI1_TX_DMA_IRQ DMA1_Channel3_IRQn
|
|
#define SPI1_TX_DMA_IRQ DMA1_Channel3_IRQn
|
|
#elif defined(BSP_UART3_RX_USING_DMA) && !defined(UART3_RX_DMA_INSTANCE)
|
|
#elif defined(BSP_UART3_RX_USING_DMA) && !defined(UART3_RX_DMA_INSTANCE)
|
|
#define UART3_DMA_RX_IRQHandler DMA1_Channel3_IRQHandler
|
|
#define UART3_DMA_RX_IRQHandler DMA1_Channel3_IRQHandler
|
|
#define UART3_RX_DMA_RCC RCC_AHB1ENR_DMA1EN
|
|
#define UART3_RX_DMA_RCC RCC_AHB1ENR_DMA1EN
|
|
#define UART3_RX_DMA_INSTANCE DMA1_Channel3
|
|
#define UART3_RX_DMA_INSTANCE DMA1_Channel3
|
|
|
|
+#if defined(DMAMUX1) /* for L4+ */
|
|
|
|
+#define UART3_RX_DMA_REQUEST DMA_REQUEST_USART3_RX
|
|
|
|
+#else /* for L4 */
|
|
#define UART3_RX_DMA_REQUEST DMA_REQUEST_2
|
|
#define UART3_RX_DMA_REQUEST DMA_REQUEST_2
|
|
|
|
+#endif /* DMAMUX1 */
|
|
#define UART3_RX_DMA_IRQ DMA1_Channel3_IRQn
|
|
#define UART3_RX_DMA_IRQ DMA1_Channel3_IRQn
|
|
#endif
|
|
#endif
|
|
|
|
|
|
@@ -49,13 +62,21 @@ extern "C" {
|
|
#define UART1_DMA_TX_IRQHandler DMA1_Channel4_IRQHandler
|
|
#define UART1_DMA_TX_IRQHandler DMA1_Channel4_IRQHandler
|
|
#define UART1_TX_DMA_RCC RCC_AHB1ENR_DMA1EN
|
|
#define UART1_TX_DMA_RCC RCC_AHB1ENR_DMA1EN
|
|
#define UART1_TX_DMA_INSTANCE DMA1_Channel4
|
|
#define UART1_TX_DMA_INSTANCE DMA1_Channel4
|
|
|
|
+#if defined(DMAMUX1) /* for L4+ */
|
|
|
|
+#define UART1_TX_DMA_REQUEST DMA_REQUEST_USART1_TX
|
|
|
|
+#else /* for L4 */
|
|
#define UART1_TX_DMA_REQUEST DMA_REQUEST_2
|
|
#define UART1_TX_DMA_REQUEST DMA_REQUEST_2
|
|
|
|
+#endif /* DMAMUX1 */
|
|
#define UART1_TX_DMA_IRQ DMA1_Channel4_IRQn
|
|
#define UART1_TX_DMA_IRQ DMA1_Channel4_IRQn
|
|
#elif defined(BSP_SPI2_RX_USING_DMA) && !defined(SPI2_RX_DMA_INSTANCE)
|
|
#elif defined(BSP_SPI2_RX_USING_DMA) && !defined(SPI2_RX_DMA_INSTANCE)
|
|
#define SPI2_DMA_RX_IRQHandler DMA1_Channel4_IRQHandler
|
|
#define SPI2_DMA_RX_IRQHandler DMA1_Channel4_IRQHandler
|
|
#define SPI2_RX_DMA_RCC RCC_AHB1ENR_DMA1EN
|
|
#define SPI2_RX_DMA_RCC RCC_AHB1ENR_DMA1EN
|
|
#define SPI2_RX_DMA_INSTANCE DMA1_Channel4
|
|
#define SPI2_RX_DMA_INSTANCE DMA1_Channel4
|
|
|
|
+#if defined(DMAMUX1) /* for L4+ */
|
|
|
|
+#define SPI2_RX_DMA_REQUEST DMA_REQUEST_SPI2_RX
|
|
|
|
+#else /* for L4 */
|
|
#define SPI2_RX_DMA_REQUEST DMA_REQUEST_1
|
|
#define SPI2_RX_DMA_REQUEST DMA_REQUEST_1
|
|
|
|
+#endif /* DMAMUX1 */
|
|
#define SPI2_RX_DMA_IRQ DMA1_Channel4_IRQn
|
|
#define SPI2_RX_DMA_IRQ DMA1_Channel4_IRQn
|
|
#endif
|
|
#endif
|
|
|
|
|
|
@@ -64,19 +85,31 @@ extern "C" {
|
|
#define UART1_DMA_RX_IRQHandler DMA1_Channel5_IRQHandler
|
|
#define UART1_DMA_RX_IRQHandler DMA1_Channel5_IRQHandler
|
|
#define UART1_RX_DMA_RCC RCC_AHB1ENR_DMA1EN
|
|
#define UART1_RX_DMA_RCC RCC_AHB1ENR_DMA1EN
|
|
#define UART1_RX_DMA_INSTANCE DMA1_Channel5
|
|
#define UART1_RX_DMA_INSTANCE DMA1_Channel5
|
|
|
|
+#if defined(DMAMUX1) /* for L4+ */
|
|
|
|
+#define UART1_RX_DMA_REQUEST DMA_REQUEST_USART1_RX
|
|
|
|
+#else /* for L4 */
|
|
#define UART1_RX_DMA_REQUEST DMA_REQUEST_2
|
|
#define UART1_RX_DMA_REQUEST DMA_REQUEST_2
|
|
|
|
+#endif /* DMAMUX1 */
|
|
#define UART1_RX_DMA_IRQ DMA1_Channel5_IRQn
|
|
#define UART1_RX_DMA_IRQ DMA1_Channel5_IRQn
|
|
#elif defined(BSP_QSPI_USING_DMA) && !defined(QSPI_DMA_INSTANCE)
|
|
#elif defined(BSP_QSPI_USING_DMA) && !defined(QSPI_DMA_INSTANCE)
|
|
#define QSPI_DMA_IRQHandler DMA1_Channel5_IRQHandler
|
|
#define QSPI_DMA_IRQHandler DMA1_Channel5_IRQHandler
|
|
#define QSPI_DMA_RCC RCC_AHB1ENR_DMA1EN
|
|
#define QSPI_DMA_RCC RCC_AHB1ENR_DMA1EN
|
|
#define QSPI_DMA_INSTANCE DMA1_Channel5
|
|
#define QSPI_DMA_INSTANCE DMA1_Channel5
|
|
|
|
+#if defined(DMAMUX1) /* for L4+ */
|
|
|
|
+#define QSPI_DMA_REQUEST DMA_REQUEST_OCTOSPI1
|
|
|
|
+#else /* for L4 */
|
|
#define QSPI_DMA_REQUEST DMA_REQUEST_5
|
|
#define QSPI_DMA_REQUEST DMA_REQUEST_5
|
|
|
|
+#endif /* DMAMUX1 */
|
|
#define QSPI_DMA_IRQ DMA1_Channel5_IRQn
|
|
#define QSPI_DMA_IRQ DMA1_Channel5_IRQn
|
|
#elif defined(BSP_SPI2_TX_USING_DMA) && !defined(SPI2_TX_DMA_INSTANCE)
|
|
#elif defined(BSP_SPI2_TX_USING_DMA) && !defined(SPI2_TX_DMA_INSTANCE)
|
|
#define SPI2_DMA_TX_IRQHandler DMA1_Channel5_IRQHandler
|
|
#define SPI2_DMA_TX_IRQHandler DMA1_Channel5_IRQHandler
|
|
#define SPI2_TX_DMA_RCC RCC_AHB1ENR_DMA1EN
|
|
#define SPI2_TX_DMA_RCC RCC_AHB1ENR_DMA1EN
|
|
#define SPI2_TX_DMA_INSTANCE DMA1_Channel5
|
|
#define SPI2_TX_DMA_INSTANCE DMA1_Channel5
|
|
|
|
+#if defined(DMAMUX1) /* for L4+ */
|
|
|
|
+#define SPI2_TX_DMA_REQUEST DMA_REQUEST_SPI2_TX
|
|
|
|
+#else /* for L4 */
|
|
#define SPI2_TX_DMA_REQUEST DMA_REQUEST_1
|
|
#define SPI2_TX_DMA_REQUEST DMA_REQUEST_1
|
|
|
|
+#endif /* DMAMUX1 */
|
|
#define SPI2_TX_DMA_IRQ DMA1_Channel5_IRQn
|
|
#define SPI2_TX_DMA_IRQ DMA1_Channel5_IRQn
|
|
#endif
|
|
#endif
|
|
|
|
|
|
@@ -85,7 +118,11 @@ extern "C" {
|
|
#define UART2_DMA_RX_IRQHandler DMA1_Channel6_IRQHandler
|
|
#define UART2_DMA_RX_IRQHandler DMA1_Channel6_IRQHandler
|
|
#define UART2_RX_DMA_RCC RCC_AHB1ENR_DMA1EN
|
|
#define UART2_RX_DMA_RCC RCC_AHB1ENR_DMA1EN
|
|
#define UART2_RX_DMA_INSTANCE DMA1_Channel6
|
|
#define UART2_RX_DMA_INSTANCE DMA1_Channel6
|
|
|
|
+#if defined(DMAMUX1) /* for L4+ */
|
|
|
|
+#define UART2_RX_DMA_REQUEST DMA_REQUEST_USART2_RX
|
|
|
|
+#else /* for L4 */
|
|
#define UART2_RX_DMA_REQUEST DMA_REQUEST_2
|
|
#define UART2_RX_DMA_REQUEST DMA_REQUEST_2
|
|
|
|
+#endif /* DMAMUX1 */
|
|
#define UART2_RX_DMA_IRQ DMA1_Channel6_IRQn
|
|
#define UART2_RX_DMA_IRQ DMA1_Channel6_IRQn
|
|
#endif
|
|
#endif
|
|
|
|
|
|
@@ -96,7 +133,11 @@ extern "C" {
|
|
#define UART5_DMA_TX_IRQHandler DMA2_Channel1_IRQHandler
|
|
#define UART5_DMA_TX_IRQHandler DMA2_Channel1_IRQHandler
|
|
#define UART5_TX_DMA_RCC RCC_AHB1ENR_DMA2EN
|
|
#define UART5_TX_DMA_RCC RCC_AHB1ENR_DMA2EN
|
|
#define UART5_TX_DMA_INSTANCE DMA2_Channel1
|
|
#define UART5_TX_DMA_INSTANCE DMA2_Channel1
|
|
|
|
+#if defined(DMAMUX1) /* for L4+ */
|
|
|
|
+#define UART5_TX_DMA_REQUEST DMA_REQUEST_UART5_TX
|
|
|
|
+#else /* for L4 */
|
|
#define UART5_TX_DMA_REQUEST DMA_REQUEST_2
|
|
#define UART5_TX_DMA_REQUEST DMA_REQUEST_2
|
|
|
|
+#endif /* DMAMUX1 */
|
|
#define UART5_TX_DMA_IRQ DMA2_Channel1_IRQn
|
|
#define UART5_TX_DMA_IRQ DMA2_Channel1_IRQn
|
|
#endif
|
|
#endif
|
|
|
|
|
|
@@ -105,7 +146,11 @@ extern "C" {
|
|
#define UART5_DMA_RX_IRQHandler DMA2_Channel2_IRQHandler
|
|
#define UART5_DMA_RX_IRQHandler DMA2_Channel2_IRQHandler
|
|
#define UART5_RX_DMA_RCC RCC_AHB1ENR_DMA2EN
|
|
#define UART5_RX_DMA_RCC RCC_AHB1ENR_DMA2EN
|
|
#define UART5_RX_DMA_INSTANCE DMA2_Channel2
|
|
#define UART5_RX_DMA_INSTANCE DMA2_Channel2
|
|
|
|
+#if defined(DMAMUX1) /* for L4+ */
|
|
|
|
+#define UART5_RX_DMA_REQUEST DMA_REQUEST_UART5_RX
|
|
|
|
+#else /* for L4 */
|
|
#define UART5_RX_DMA_REQUEST DMA_REQUEST_2
|
|
#define UART5_RX_DMA_REQUEST DMA_REQUEST_2
|
|
|
|
+#endif /* DMAMUX1 */
|
|
#define UART5_RX_DMA_IRQ DMA2_Channel2_IRQn
|
|
#define UART5_RX_DMA_IRQ DMA2_Channel2_IRQn
|
|
#endif
|
|
#endif
|
|
|
|
|
|
@@ -114,7 +159,11 @@ extern "C" {
|
|
#define SPI1_DMA_RX_IRQHandler DMA2_Channel3_IRQHandler
|
|
#define SPI1_DMA_RX_IRQHandler DMA2_Channel3_IRQHandler
|
|
#define SPI1_RX_DMA_RCC RCC_AHB1ENR_DMA2EN
|
|
#define SPI1_RX_DMA_RCC RCC_AHB1ENR_DMA2EN
|
|
#define SPI1_RX_DMA_INSTANCE DMA2_Channel3
|
|
#define SPI1_RX_DMA_INSTANCE DMA2_Channel3
|
|
|
|
+#if defined(DMAMUX1) /* for L4+ */
|
|
|
|
+#define SPI1_RX_DMA_REQUEST DMA_REQUEST_SPI1_RX
|
|
|
|
+#else /* for L4 */
|
|
#define SPI1_RX_DMA_REQUEST DMA_REQUEST_4
|
|
#define SPI1_RX_DMA_REQUEST DMA_REQUEST_4
|
|
|
|
+#endif /* DMAMUX1 */
|
|
#define SPI1_RX_DMA_IRQ DMA2_Channel3_IRQn
|
|
#define SPI1_RX_DMA_IRQ DMA2_Channel3_IRQn
|
|
#endif
|
|
#endif
|
|
|
|
|
|
@@ -123,7 +172,11 @@ extern "C" {
|
|
#define SPI1_DMA_TX_IRQHandler DMA2_Channel4_IRQHandler
|
|
#define SPI1_DMA_TX_IRQHandler DMA2_Channel4_IRQHandler
|
|
#define SPI1_TX_DMA_RCC RCC_AHB1ENR_DMA2EN
|
|
#define SPI1_TX_DMA_RCC RCC_AHB1ENR_DMA2EN
|
|
#define SPI1_TX_DMA_INSTANCE DMA2_Channel4
|
|
#define SPI1_TX_DMA_INSTANCE DMA2_Channel4
|
|
|
|
+#if defined(DMAMUX1) /* for L4+ */
|
|
|
|
+#define SPI1_TX_DMA_REQUEST DMA_REQUEST_SPI1_TX
|
|
|
|
+#else /* for L4 */
|
|
#define SPI1_TX_DMA_REQUEST DMA_REQUEST_4
|
|
#define SPI1_TX_DMA_REQUEST DMA_REQUEST_4
|
|
|
|
+#endif /* DMAMUX1 */
|
|
#define SPI1_TX_DMA_IRQ DMA2_Channel4_IRQn
|
|
#define SPI1_TX_DMA_IRQ DMA2_Channel4_IRQn
|
|
#endif
|
|
#endif
|
|
|
|
|
|
@@ -134,7 +187,11 @@ extern "C" {
|
|
#define UART1_DMA_TX_IRQHandler DMA2_Channel6_IRQHandler
|
|
#define UART1_DMA_TX_IRQHandler DMA2_Channel6_IRQHandler
|
|
#define UART1_TX_DMA_RCC RCC_AHB1ENR_DMA2EN
|
|
#define UART1_TX_DMA_RCC RCC_AHB1ENR_DMA2EN
|
|
#define UART1_TX_DMA_INSTANCE DMA2_Channel6
|
|
#define UART1_TX_DMA_INSTANCE DMA2_Channel6
|
|
|
|
+#if defined(DMAMUX1) /* for L4+ */
|
|
|
|
+#define UART1_TX_DMA_REQUEST DMA_REQUEST_USART1_TX
|
|
|
|
+#else /* for L4 */
|
|
#define UART1_TX_DMA_REQUEST DMA_REQUEST_2
|
|
#define UART1_TX_DMA_REQUEST DMA_REQUEST_2
|
|
|
|
+#endif /* DMAMUX1 */
|
|
#define UART1_TX_DMA_IRQ DMA2_Channel6_IRQn
|
|
#define UART1_TX_DMA_IRQ DMA2_Channel6_IRQn
|
|
#endif
|
|
#endif
|
|
|
|
|
|
@@ -143,19 +200,31 @@ extern "C" {
|
|
#define UART1_DMA_RX_IRQHandler DMA2_Channel7_IRQHandler
|
|
#define UART1_DMA_RX_IRQHandler DMA2_Channel7_IRQHandler
|
|
#define UART1_RX_DMA_RCC RCC_AHB1ENR_DMA2EN
|
|
#define UART1_RX_DMA_RCC RCC_AHB1ENR_DMA2EN
|
|
#define UART1_RX_DMA_INSTANCE DMA2_Channel7
|
|
#define UART1_RX_DMA_INSTANCE DMA2_Channel7
|
|
|
|
+#if defined(DMAMUX1) /* for L4+ */
|
|
|
|
+#define UART1_RX_DMA_REQUEST DMA_REQUEST_USART1_RX
|
|
|
|
+#else /* for L4 */
|
|
#define UART1_RX_DMA_REQUEST DMA_REQUEST_2
|
|
#define UART1_RX_DMA_REQUEST DMA_REQUEST_2
|
|
|
|
+#endif /* DMAMUX1 */
|
|
#define UART1_RX_DMA_IRQ DMA2_Channel7_IRQn
|
|
#define UART1_RX_DMA_IRQ DMA2_Channel7_IRQn
|
|
#elif defined(BSP_QSPI_USING_DMA) && !defined(QSPI_DMA_INSTANCE)
|
|
#elif defined(BSP_QSPI_USING_DMA) && !defined(QSPI_DMA_INSTANCE)
|
|
#define QSPI_DMA_IRQHandler DMA2_Channel7_IRQHandler
|
|
#define QSPI_DMA_IRQHandler DMA2_Channel7_IRQHandler
|
|
#define QSPI_DMA_RCC RCC_AHB1ENR_DMA2EN
|
|
#define QSPI_DMA_RCC RCC_AHB1ENR_DMA2EN
|
|
#define QSPI_DMA_INSTANCE DMA2_Channel7
|
|
#define QSPI_DMA_INSTANCE DMA2_Channel7
|
|
|
|
+#if defined(DMAMUX1) /* for L4+ */
|
|
|
|
+#define QSPI_DMA_REQUEST DMA_REQUEST_OCTOSPI1
|
|
|
|
+#else /* for L4 */
|
|
#define QSPI_DMA_REQUEST DMA_REQUEST_3
|
|
#define QSPI_DMA_REQUEST DMA_REQUEST_3
|
|
|
|
+#endif /* DMAMUX1 */
|
|
#define QSPI_DMA_IRQ DMA2_Channel7_IRQn
|
|
#define QSPI_DMA_IRQ DMA2_Channel7_IRQn
|
|
#elif defined(BSP_LPUART1_RX_USING_DMA) && !defined(LPUART1_RX_DMA_INSTANCE)
|
|
#elif defined(BSP_LPUART1_RX_USING_DMA) && !defined(LPUART1_RX_DMA_INSTANCE)
|
|
#define LPUART1_DMA_RX_IRQHandler DMA2_Channel7_IRQHandler
|
|
#define LPUART1_DMA_RX_IRQHandler DMA2_Channel7_IRQHandler
|
|
#define LPUART1_RX_DMA_RCC RCC_AHB1ENR_DMA2EN
|
|
#define LPUART1_RX_DMA_RCC RCC_AHB1ENR_DMA2EN
|
|
#define LPUART1_RX_DMA_INSTANCE DMA2_Channel7
|
|
#define LPUART1_RX_DMA_INSTANCE DMA2_Channel7
|
|
|
|
+#if defined(DMAMUX1) /* for L4+ */
|
|
|
|
+#define LPUART1_RX_DMA_REQUEST DMA_REQUEST_LPUART1_RX
|
|
|
|
+#else /* for L4 */
|
|
#define LPUART1_RX_DMA_REQUEST DMA_REQUEST_4
|
|
#define LPUART1_RX_DMA_REQUEST DMA_REQUEST_4
|
|
|
|
+#endif /* DMAMUX1 */
|
|
#define LPUART1_RX_DMA_IRQ DMA2_Channel7_IRQn
|
|
#define LPUART1_RX_DMA_IRQ DMA2_Channel7_IRQn
|
|
#endif
|
|
#endif
|
|
|
|
|