123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428 |
- /*!
- \file gd32f4xx_dma.c
- \brief definitions for the DMA
- \version 2016-08-15, V1.0.0, firmware for GD32F4xx
- \version 2018-12-12, V2.0.0, firmware for GD32F4xx
- \version 2020-09-30, V2.1.0, firmware for GD32F4xx
- */
- /*
- Copyright (c) 2020, GigaDevice Semiconductor Inc.
- Redistribution and use in source and binary forms, with or without modification,
- are permitted provided that the following conditions are met:
- 1. Redistributions of source code must retain the above copyright notice, this
- list of conditions and the following disclaimer.
- 2. Redistributions in binary form must reproduce the above copyright notice,
- this list of conditions and the following disclaimer in the documentation
- and/or other materials provided with the distribution.
- 3. Neither the name of the copyright holder nor the names of its contributors
- may be used to endorse or promote products derived from this software without
- specific prior written permission.
- THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
- AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
- WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
- IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
- INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
- NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
- PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
- WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
- ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
- OF SUCH DAMAGE.
- */
- #ifndef GD32F4XX_DMA_H
- #define GD32F4XX_DMA_H
- #include "gd32f4xx.h"
- /* DMA definitions */
- #define DMA0 (DMA_BASE) /*!< DMA0 base address */
- #define DMA1 (DMA_BASE + 0x0400U) /*!< DMA1 base address */
- /* registers definitions */
- #define DMA_INTF0(dmax) REG32((dmax) + 0x00U) /*!< DMA interrupt flag register 0 */
- #define DMA_INTF1(dmax) REG32((dmax) + 0x04U) /*!< DMA interrupt flag register 1 */
- #define DMA_INTC0(dmax) REG32((dmax) + 0x08U) /*!< DMA interrupt flag clear register 0 */
- #define DMA_INTC1(dmax) REG32((dmax) + 0x0CU) /*!< DMA interrupt flag clear register 1 */
- #define DMA_CH0CTL(dmax) REG32((dmax) + 0x10U) /*!< DMA channel 0 control register */
- #define DMA_CH0CNT(dmax) REG32((dmax) + 0x14U) /*!< DMA channel 0 counter register */
- #define DMA_CH0PADDR(dmax) REG32((dmax) + 0x18U) /*!< DMA channel 0 peripheral base address register */
- #define DMA_CH0M0ADDR(dmax) REG32((dmax) + 0x1CU) /*!< DMA channel 0 memory 0 base address register */
- #define DMA_CH0M1ADDR(dmax) REG32((dmax) + 0x20U) /*!< DMA channel 0 memory 1 base address register */
- #define DMA_CH0FCTL(dmax) REG32((dmax) + 0x24U) /*!< DMA channel 0 FIFO control register */
- #define DMA_CH1CTL(dmax) REG32((dmax) + 0x28U) /*!< DMA channel 1 control register */
- #define DMA_CH1CNT(dmax) REG32((dmax) + 0x2CU) /*!< DMA channel 1 counter register */
- #define DMA_CH1PADDR(dmax) REG32((dmax) + 0x30U) /*!< DMA channel 1 peripheral base address register */
- #define DMA_CH1M0ADDR(dmax) REG32((dmax) + 0x34U) /*!< DMA channel 1 memory 0 base address register */
- #define DMA_CH1M1ADDR(dmax) REG32((dmax) + 0x38U) /*!< DMA channel 1 memory 1 base address register */
- #define DMA_CH1FCTL(dmax) REG32((dmax) + 0x3CU) /*!< DMA channel 1 FIFO control register */
- #define DMA_CH2CTL(dmax) REG32((dmax) + 0x40U) /*!< DMA channel 2 control register */
- #define DMA_CH2CNT(dmax) REG32((dmax) + 0x44U) /*!< DMA channel 2 counter register */
- #define DMA_CH2PADDR(dmax) REG32((dmax) + 0x48U) /*!< DMA channel 2 peripheral base address register */
- #define DMA_CH2M0ADDR(dmax) REG32((dmax) + 0x4CU) /*!< DMA channel 2 memory 0 base address register */
- #define DMA_CH2M1ADDR(dmax) REG32((dmax) + 0x50U) /*!< DMA channel 2 memory 1 base address register */
- #define DMA_CH2FCTL(dmax) REG32((dmax) + 0x54U) /*!< DMA channel 2 FIFO control register */
- #define DMA_CH3CTL(dmax) REG32((dmax) + 0x58U) /*!< DMA channel 3 control register */
- #define DMA_CH3CNT(dmax) REG32((dmax) + 0x5CU) /*!< DMA channel 3 counter register */
- #define DMA_CH3PADDR(dmax) REG32((dmax) + 0x60U) /*!< DMA channel 3 peripheral base address register */
- #define DMA_CH3M0ADDR(dmax) REG32((dmax) + 0x64U) /*!< DMA channel 3 memory 0 base address register */
- #define DMA_CH3M1ADDR(dmax) REG32((dmax) + 0x68U) /*!< DMA channel 3 memory 1 base address register */
- #define DMA_CH3FCTL(dmax) REG32((dmax) + 0x6CU) /*!< DMA channel 3 FIFO control register */
- #define DMA_CH4CTL(dmax) REG32((dmax) + 0x70U) /*!< DMA channel 4 control register */
- #define DMA_CH4CNT(dmax) REG32((dmax) + 0x74U) /*!< DMA channel 4 counter register */
- #define DMA_CH4PADDR(dmax) REG32((dmax) + 0x78U) /*!< DMA channel 4 peripheral base address register */
- #define DMA_CH4M0ADDR(dmax) REG32((dmax) + 0x7CU) /*!< DMA channel 4 memory 0 base address register */
- #define DMA_CH4M1ADDR(dmax) REG32((dmax) + 0x80U) /*!< DMA channel 4 memory 1 base address register */
- #define DMA_CH4FCTL(dmax) REG32((dmax) + 0x84U) /*!< DMA channel 4 FIFO control register */
- #define DMA_CH5CTL(dmax) REG32((dmax) + 0x88U) /*!< DMA channel 5 control register */
- #define DMA_CH5CNT(dmax) REG32((dmax) + 0x8CU) /*!< DMA channel 5 counter register */
- #define DMA_CH5PADDR(dmax) REG32((dmax) + 0x90U) /*!< DMA channel 5 peripheral base address register */
- #define DMA_CH5M0ADDR(dmax) REG32((dmax) + 0x94U) /*!< DMA channel 5 memory 0 base address register */
- #define DMA_CH5M1ADDR(dmax) REG32((dmax) + 0x98U) /*!< DMA channel 5 memory 1 base address register */
- #define DMA_CH5FCTL(dmax) REG32((dmax) + 0x9CU) /*!< DMA channel 5 FIFO control register */
- #define DMA_CH6CTL(dmax) REG32((dmax) + 0xA0U) /*!< DMA channel 6 control register */
- #define DMA_CH6CNT(dmax) REG32((dmax) + 0xA4U) /*!< DMA channel 6 counter register */
- #define DMA_CH6PADDR(dmax) REG32((dmax) + 0xA8U) /*!< DMA channel 6 peripheral base address register */
- #define DMA_CH6M0ADDR(dmax) REG32((dmax) + 0xACU) /*!< DMA channel 6 memory 0 base address register */
- #define DMA_CH6M1ADDR(dmax) REG32((dmax) + 0xB0U) /*!< DMA channel 6 memory 1 base address register */
- #define DMA_CH6FCTL(dmax) REG32((dmax) + 0xB4U) /*!< DMA channel 6 FIFO control register */
- #define DMA_CH7CTL(dmax) REG32((dmax) + 0xB8U) /*!< DMA channel 7 control register */
- #define DMA_CH7CNT(dmax) REG32((dmax) + 0xBCU) /*!< DMA channel 7 counter register */
- #define DMA_CH7PADDR(dmax) REG32((dmax) + 0xC0U) /*!< DMA channel 7 peripheral base address register */
- #define DMA_CH7M0ADDR(dmax) REG32((dmax) + 0xC4U) /*!< DMA channel 7 memory 0 base address register */
- #define DMA_CH7M1ADDR(dmax) REG32((dmax) + 0xC8U) /*!< DMA channel 7 memory 1 base address register */
- #define DMA_CH7FCTL(dmax) REG32((dmax) + 0xCCU) /*!< DMA channel 7 FIFO control register */
- /* bits definitions */
- /* DMA_INTF */
- #define DMA_INTF_FEEIF BIT(0) /*!< FIFO error and exception flag */
- #define DMA_INTF_SDEIF BIT(2) /*!< single data mode exception flag */
- #define DMA_INTF_TAEIF BIT(3) /*!< transfer access error flag */
- #define DMA_INTF_HTFIF BIT(4) /*!< half transfer finish flag */
- #define DMA_INTF_FTFIF BIT(5) /*!< full transger finish flag */
- /* DMA_INTC */
- #define DMA_INTC_FEEIFC BIT(0) /*!< clear FIFO error and exception flag */
- #define DMA_INTC_SDEIFC BIT(2) /*!< clear single data mode exception flag */
- #define DMA_INTC_TAEIFC BIT(3) /*!< clear single data mode exception flag */
- #define DMA_INTC_HTFIFC BIT(4) /*!< clear half transfer finish flag */
- #define DMA_INTC_FTFIFC BIT(5) /*!< clear full transger finish flag */
- /* DMA_CHxCTL,x=0..7 */
- #define DMA_CHXCTL_CHEN BIT(0) /*!< channel x enable */
- #define DMA_CHXCTL_SDEIE BIT(1) /*!< enable bit for channel x single data mode exception interrupt */
- #define DMA_CHXCTL_TAEIE BIT(2) /*!< enable bit for channel x tranfer access error interrupt */
- #define DMA_CHXCTL_HTFIE BIT(3) /*!< enable bit for channel x half transfer finish interrupt */
- #define DMA_CHXCTL_FTFIE BIT(4) /*!< enable bit for channel x full transfer finish interrupt */
- #define DMA_CHXCTL_TFCS BIT(5) /*!< transfer flow controller select */
- #define DMA_CHXCTL_TM BITS(6,7) /*!< transfer mode */
- #define DMA_CHXCTL_CMEN BIT(8) /*!< circulation mode */
- #define DMA_CHXCTL_PNAGA BIT(9) /*!< next address generation algorithm of peripheral */
- #define DMA_CHXCTL_MNAGA BIT(10) /*!< next address generation algorithm of memory */
- #define DMA_CHXCTL_PWIDTH BITS(11,12) /*!< transfer width of peipheral */
- #define DMA_CHXCTL_MWIDTH BITS(13,14) /*!< transfer width of memory */
- #define DMA_CHXCTL_PAIF BIT(15) /*!< peripheral address increment fixed */
- #define DMA_CHXCTL_PRIO BITS(16,17) /*!< priority level */
- #define DMA_CHXCTL_SBMEN BIT(18) /*!< switch-buffer mode enable */
- #define DMA_CHXCTL_MBS BIT(19) /*!< memory buffer select */
- #define DMA_CHXCTL_PBURST BITS(21,22) /*!< transfer burst type of peripheral */
- #define DMA_CHXCTL_MBURST BITS(23,24) /*!< transfer burst type of memory */
- #define DMA_CHXCTL_PERIEN BITS(25,27) /*!< peripheral enable */
- /* DMA_CHxCNT,x=0..7 */
- #define DMA_CHXCNT_CNT BITS(0,15) /*!< transfer counter */
- /* DMA_CHxPADDR,x=0..7 */
- #define DMA_CHXPADDR_PADDR BITS(0,31) /*!< peripheral base address */
- /* DMA_CHxM0ADDR,x=0..7 */
- #define DMA_CHXM0ADDR_M0ADDR BITS(0,31) /*!< memory 0 base address */
- /* DMA_CHxM1ADDR,x=0..7 */
- #define DMA_CHXM1ADDR_M0ADDR BITS(0,31) /*!< memory 1 base address */
- /* DMA_CHxFCTL,x=0..7 */
- #define DMA_CHXFCTL_FCCV BITS(0,1) /*!< FIFO counter critical value */
- #define DMA_CHXFCTL_MDMEN BIT(2) /*!< multi-data mode enable */
- #define DMA_CHXFCTL_FCNT BITS(3,5) /*!< FIFO counter */
- #define DMA_CHXFCTL_FEEIE BIT(7) /*!< FIFO exception interrupt enable */
- /* constants definitions */
- /* DMA channel select */
- typedef enum
- {
- DMA_CH0 = 0, /*!< DMA Channel 0 */
- DMA_CH1, /*!< DMA Channel 1 */
- DMA_CH2, /*!< DMA Channel 2 */
- DMA_CH3, /*!< DMA Channel 3 */
- DMA_CH4, /*!< DMA Channel 4 */
- DMA_CH5, /*!< DMA Channel 5 */
- DMA_CH6, /*!< DMA Channel 6 */
- DMA_CH7 /*!< DMA Channel 7 */
- } dma_channel_enum;
- /* DMA peripheral select */
- typedef enum
- {
- DMA_SUBPERI0 = 0, /*!< DMA Peripheral 0 */
- DMA_SUBPERI1, /*!< DMA Peripheral 1 */
- DMA_SUBPERI2, /*!< DMA Peripheral 2 */
- DMA_SUBPERI3, /*!< DMA Peripheral 3 */
- DMA_SUBPERI4, /*!< DMA Peripheral 4 */
- DMA_SUBPERI5, /*!< DMA Peripheral 5 */
- DMA_SUBPERI6, /*!< DMA Peripheral 6 */
- DMA_SUBPERI7 /*!< DMA Peripheral 7 */
- } dma_subperipheral_enum;
- /* DMA multidata mode initialize struct */
- typedef struct
- {
- uint32_t periph_addr; /*!< peripheral base address */
- uint32_t periph_width; /*!< transfer data size of peripheral */
- uint32_t periph_inc; /*!< peripheral increasing mode */
- uint32_t memory0_addr; /*!< memory 0 base address */
- uint32_t memory_width; /*!< transfer data size of memory */
- uint32_t memory_inc; /*!< memory increasing mode */
- uint32_t memory_burst_width; /*!< multi data mode enable */
- uint32_t periph_burst_width; /*!< multi data mode enable */
- uint32_t critical_value; /*!< FIFO critical */
- uint32_t circular_mode; /*!< DMA circular mode */
- uint32_t direction; /*!< channel data transfer direction */
- uint32_t number; /*!< channel transfer number */
- uint32_t priority; /*!< channel priority level */
- }dma_multi_data_parameter_struct;
- /* DMA singledata mode initialize struct */
- typedef struct
- {
- uint32_t periph_addr; /*!< peripheral base address */
- uint32_t periph_inc; /*!< peripheral increasing mode */
- uint32_t memory0_addr; /*!< memory 0 base address */
- uint32_t memory_inc; /*!< memory increasing mode */
- uint32_t periph_memory_width; /*!< transfer data size of peripheral */
- uint32_t circular_mode; /*!< DMA circular mode */
- uint32_t direction; /*!< channel data transfer direction */
- uint32_t number; /*!< channel transfer number */
- uint32_t priority; /*!< channel priority level */
- } dma_single_data_parameter_struct;
- #define DMA_FLAG_ADD(flag,channel) ((uint32_t)((flag)<<((((uint32_t)(channel)*6U))+((uint32_t)(((uint32_t)(channel)) >> 1U)&0x01U)*4U))) /*!< DMA channel flag shift */
- /* DMA_register address */
- #define DMA_CHCTL(dma,channel) REG32(((dma) + 0x10U) + 0x18U*(channel)) /*!< the address of DMA channel CHXCTL register */
- #define DMA_CHCNT(dma,channel) REG32(((dma) + 0x14U) + 0x18U*(channel)) /*!< the address of DMA channel CHXCNT register */
- #define DMA_CHPADDR(dma,channel) REG32(((dma) + 0x18U) + 0x18U*(channel)) /*!< the address of DMA channel CHXPADDR register */
- #define DMA_CHM0ADDR(dma,channel) REG32(((dma) + 0x1CU) + 0x18U*(channel)) /*!< the address of DMA channel CHXM0ADDR register */
- #define DMA_CHM1ADDR(dma,channel) REG32(((dma) + 0x20U) + 0x18U*(channel)) /*!< the address of DMA channel CHXM1ADDR register */
- #define DMA_CHFCTL(dma,channel) REG32(((dma) + 0x24U) + 0x18U*(channel)) /*!< the address of DMA channel CHXMADDR register */
- /* peripheral select */
- #define CHCTL_PERIEN(regval) (BITS(25,27) & ((uint32_t)(regval) << 25))
- #define DMA_PERIPH_0_SELECT CHCTL_PERIEN(0) /*!< peripheral 0 select */
- #define DMA_PERIPH_1_SELECT CHCTL_PERIEN(1) /*!< peripheral 1 select */
- #define DMA_PERIPH_2_SELECT CHCTL_PERIEN(2) /*!< peripheral 2 select */
- #define DMA_PERIPH_3_SELECT CHCTL_PERIEN(3) /*!< peripheral 3 select */
- #define DMA_PERIPH_4_SELECT CHCTL_PERIEN(4) /*!< peripheral 4 select */
- #define DMA_PERIPH_5_SELECT CHCTL_PERIEN(5) /*!< peripheral 5 select */
- #define DMA_PERIPH_6_SELECT CHCTL_PERIEN(6) /*!< peripheral 6 select */
- #define DMA_PERIPH_7_SELECT CHCTL_PERIEN(7) /*!< peripheral 7 select */
- /* burst type of memory */
- #define CHCTL_MBURST(regval) (BITS(23,24) & ((uint32_t)(regval) << 23))
- #define DMA_MEMORY_BURST_SINGLE CHCTL_MBURST(0) /*!< single burst */
- #define DMA_MEMORY_BURST_4_BEAT CHCTL_MBURST(1) /*!< 4-beat burst */
- #define DMA_MEMORY_BURST_8_BEAT CHCTL_MBURST(2) /*!< 8-beat burst */
- #define DMA_MEMORY_BURST_16_BEAT CHCTL_MBURST(3) /*!< 16-beat burst */
- /* burst type of peripheral */
- #define CHCTL_PBURST(regval) (BITS(21,22) & ((uint32_t)(regval) << 21))
- #define DMA_PERIPH_BURST_SINGLE CHCTL_PBURST(0) /*!< single burst */
- #define DMA_PERIPH_BURST_4_BEAT CHCTL_PBURST(1) /*!< 4-beat burst */
- #define DMA_PERIPH_BURST_8_BEAT CHCTL_PBURST(2) /*!< 8-beat burst */
- #define DMA_PERIPH_BURST_16_BEAT CHCTL_PBURST(3) /*!< 16-beat burst */
- /* channel priority level */
- #define CHCTL_PRIO(regval) (BITS(16,17) & ((uint32_t)(regval) << 16))
- #define DMA_PRIORITY_LOW CHCTL_PRIO(0) /*!< low priority */
- #define DMA_PRIORITY_MEDIUM CHCTL_PRIO(1) /*!< medium priority */
- #define DMA_PRIORITY_HIGH CHCTL_PRIO(2) /*!< high priority */
- #define DMA_PRIORITY_ULTRA_HIGH CHCTL_PRIO(3) /*!< ultra high priority */
- /* transfer data width of memory */
- #define CHCTL_MWIDTH(regval) (BITS(13,14) & ((uint32_t)(regval) << 13))
- #define DMA_MEMORY_WIDTH_8BIT CHCTL_MWIDTH(0) /*!< transfer data width of memory is 8-bit */
- #define DMA_MEMORY_WIDTH_16BIT CHCTL_MWIDTH(1) /*!< transfer data width of memory is 16-bit */
- #define DMA_MEMORY_WIDTH_32BIT CHCTL_MWIDTH(2) /*!< transfer data width of memory is 32-bit */
- /* transfer data width of peripheral */
- #define CHCTL_PWIDTH(regval) (BITS(11,12) & ((uint32_t)(regval) << 11))
- #define DMA_PERIPH_WIDTH_8BIT CHCTL_PWIDTH(0) /*!< transfer data width of peripheral is 8-bit */
- #define DMA_PERIPH_WIDTH_16BIT CHCTL_PWIDTH(1) /*!< transfer data width of peripheral is 16-bit */
- #define DMA_PERIPH_WIDTH_32BIT CHCTL_PWIDTH(2) /*!< transfer data width of peripheral is 32-bit */
- /* channel transfer mode */
- #define CHCTL_TM(regval) (BITS(6,7) & ((uint32_t)(regval) << 6))
- #define DMA_PERIPH_TO_MEMORY CHCTL_TM(0) /*!< read from peripheral and write to memory */
- #define DMA_MEMORY_TO_PERIPH CHCTL_TM(1) /*!< read from memory and write to peripheral */
- #define DMA_MEMORY_TO_MEMORY CHCTL_TM(2) /*!< read from memory and write to memory */
- /* FIFO counter critical value */
- #define CHFCTL_FCCV(regval) (BITS(0,1) & ((uint32_t)(regval) << 0))
- #define DMA_FIFO_1_WORD CHFCTL_FCCV(0) /*!< critical value 1 word */
- #define DMA_FIFO_2_WORD CHFCTL_FCCV(1) /*!< critical value 2 word */
- #define DMA_FIFO_3_WORD CHFCTL_FCCV(2) /*!< critical value 3 word */
- #define DMA_FIFO_4_WORD CHFCTL_FCCV(3) /*!< critical value 4 word */
- /* memory select */
- #define DMA_MEMORY_0 ((uint32_t)0x00000000U) /*!< select memory 0 */
- #define DMA_MEMORY_1 ((uint32_t)0x00000001U) /*!< select memory 1 */
- /* DMA circular mode */
- #define DMA_CIRCULAR_MODE_ENABLE ((uint32_t)0x00000000U) /*!< circular mode enable */
- #define DMA_CIRCULAR_MODE_DISABLE ((uint32_t)0x00000001U) /*!< circular mode disable */
- /* DMA flow controller select */
- #define DMA_FLOW_CONTROLLER_DMA ((uint32_t)0x00000000U) /*!< DMA is the flow controler */
- #define DMA_FLOW_CONTROLLER_PERI ((uint32_t)0x00000001U) /*!< peripheral is the flow controler */
- /* peripheral increasing mode */
- #define DMA_PERIPH_INCREASE_ENABLE ((uint32_t)0x00000000U) /*!< next address of peripheral is increasing address mode */
- #define DMA_PERIPH_INCREASE_DISABLE ((uint32_t)0x00000001U) /*!< next address of peripheral is fixed address mode */
- #define DMA_PERIPH_INCREASE_FIX ((uint32_t)0x00000002U) /*!< next address of peripheral is increasing fixed */
- /* memory increasing mode */
- #define DMA_MEMORY_INCREASE_ENABLE ((uint32_t)0x00000000U) /*!< next address of memory is increasing address mode */
- #define DMA_MEMORY_INCREASE_DISABLE ((uint32_t)0x00000001U) /*!< next address of memory is fixed address mode */
- /* FIFO status */
- #define DMA_FIFO_STATUS_NODATA ((uint32_t)0x00000000U) /*!< the data in the FIFO less than 1 word */
- #define DMA_FIFO_STATUS_1_WORD ((uint32_t)0x00000001U) /*!< the data in the FIFO more than 1 word, less than 2 words */
- #define DMA_FIFO_STATUS_2_WORD ((uint32_t)0x00000002U) /*!< the data in the FIFO more than 2 word, less than 3 words */
- #define DMA_FIFO_STATUS_3_WORD ((uint32_t)0x00000003U) /*!< the data in the FIFO more than 3 word, less than 4 words */
- #define DMA_FIFO_STATUS_EMPTY ((uint32_t)0x00000004U) /*!< the data in the FIFO is empty */
- #define DMA_FIFO_STATUS_FULL ((uint32_t)0x00000005U) /*!< the data in the FIFO is full */
- /* DMA reset value */
- #define DMA_CHCTL_RESET_VALUE ((uint32_t)0x00000000U) /*!< the reset value of DMA channel CHXCTL register */
- #define DMA_CHCNT_RESET_VALUE ((uint32_t)0x00000000U) /*!< the reset value of DMA channel CHXCNT register */
- #define DMA_CHPADDR_RESET_VALUE ((uint32_t)0x00000000U) /*!< the reset value of DMA channel CHXPADDR register */
- #define DMA_CHMADDR_RESET_VALUE ((uint32_t)0x00000000U) /*!< the reset value of DMA channel CHXMADDR register */
- #define DMA_CHINTF_RESET_VALUE ((uint32_t)0x0000003DU) /*!< clear DMA channel CHXINTFS register */
- #define DMA_CHFCTL_RESET_VALUE ((uint32_t)0x00000000U) /*!< the reset value of DMA channel CHXFCTL register */
- /* DMA_INTF register */
- /* interrupt flag bits */
- #define DMA_INT_FLAG_FEE DMA_INTF_FEEIF /*!< FIFO error and exception flag */
- #define DMA_INT_FLAG_SDE DMA_INTF_SDEIF /*!< single data mode exception flag */
- #define DMA_INT_FLAG_TAE DMA_INTF_TAEIF /*!< transfer access error flag */
- #define DMA_INT_FLAG_HTF DMA_INTF_HTFIF /*!< half transfer finish flag */
- #define DMA_INT_FLAG_FTF DMA_INTF_FTFIF /*!< full transfer finish flag */
- /* flag bits */
- #define DMA_FLAG_FEE DMA_INTF_FEEIF /*!< FIFO error and exception flag */
- #define DMA_FLAG_SDE DMA_INTF_SDEIF /*!< single data mode exception flag */
- #define DMA_FLAG_TAE DMA_INTF_TAEIF /*!< transfer access error flag */
- #define DMA_FLAG_HTF DMA_INTF_HTFIF /*!< half transfer finish flag */
- #define DMA_FLAG_FTF DMA_INTF_FTFIF /*!< full transfer finish flag */
- /* function declarations */
- /* DMA deinitialization and initialization functions */
- /* deinitialize DMA a channel registers */
- void dma_deinit(uint32_t dma_periph, dma_channel_enum channelx);
- /* initialize the DMA single data mode parameters struct with the default values */
- void dma_single_data_para_struct_init(dma_single_data_parameter_struct* init_struct);
- /* initialize the DMA multi data mode parameters struct with the default values */
- void dma_multi_data_para_struct_init(dma_multi_data_parameter_struct* init_struct);
- /* DMA single data mode initialize */
- void dma_single_data_mode_init(uint32_t dma_periph, dma_channel_enum channelx, dma_single_data_parameter_struct* init_struct);
- /* DMA multi data mode initialize */
- void dma_multi_data_mode_init(uint32_t dma_periph, dma_channel_enum channelx, dma_multi_data_parameter_struct* init_struct);
- /* DMA configuration functions */
- /* set DMA peripheral base address */
- void dma_periph_address_config(uint32_t dma_periph, dma_channel_enum channelx, uint32_t address);
- /* set DMA Memory base address */
- void dma_memory_address_config(uint32_t dma_periph, dma_channel_enum channelx, uint8_t memory_flag, uint32_t address);
- /* set the number of remaining data to be transferred by the DMA */
- void dma_transfer_number_config(uint32_t dma_periph,dma_channel_enum channelx, uint32_t number);
- /* get the number of remaining data to be transferred by the DMA */
- uint32_t dma_transfer_number_get(uint32_t dma_periph, dma_channel_enum channelx);
- /* configure priority level of DMA channel */
- void dma_priority_config(uint32_t dma_periph, dma_channel_enum channelx, uint32_t priority);
- /* configure transfer burst beats of memory */
- void dma_memory_burst_beats_config (uint32_t dma_periph, dma_channel_enum channelx, uint32_t mbeat);
- /* configure transfer burst beats of peripheral */
- void dma_periph_burst_beats_config (uint32_t dma_periph, dma_channel_enum channelx, uint32_t pbeat);
- /* configure transfer data size of memory */
- void dma_memory_width_config (uint32_t dma_periph, dma_channel_enum channelx, uint32_t msize);
- /* configure transfer data size of peripheral */
- void dma_periph_width_config (uint32_t dma_periph, dma_channel_enum channelx, uint32_t psize);
- /* configure next address increasement algorithm of memory */
- void dma_memory_address_generation_config(uint32_t dma_periph, dma_channel_enum channelx, uint8_t generation_algorithm);
- /* configure next address increasement algorithm of peripheral */
- void dma_peripheral_address_generation_config(uint32_t dma_periph, dma_channel_enum channelx, uint8_t generation_algorithm);
- /* enable DMA circulation mode */
- void dma_circulation_enable(uint32_t dma_periph, dma_channel_enum channelx);
- /* disable DMA circulation mode */
- void dma_circulation_disable(uint32_t dma_periph, dma_channel_enum channelx);
- /* enable DMA channel */
- void dma_channel_enable(uint32_t dma_periph, dma_channel_enum channelx);
- /* disable DMA channel */
- void dma_channel_disable(uint32_t dma_periph, dma_channel_enum channelx);
- /* configure the direction of data transfer on the channel */
- void dma_transfer_direction_config(uint32_t dma_periph, dma_channel_enum channelx, uint8_t direction);
- /* DMA switch buffer mode config */
- void dma_switch_buffer_mode_config(uint32_t dma_periph, dma_channel_enum channelx, uint32_t memory1_addr, uint32_t memory_select);
- /* DMA using memory get */
- uint32_t dma_using_memory_get(uint32_t dma_periph, dma_channel_enum channelx);
- /* DMA channel peripheral select */
- void dma_channel_subperipheral_select(uint32_t dma_periph, dma_channel_enum channelx, dma_subperipheral_enum sub_periph);
- /* DMA flow controller configure */
- void dma_flow_controller_config(uint32_t dma_periph, dma_channel_enum channelx, uint32_t controller);
- /* DMA flow controller enable */
- void dma_switch_buffer_mode_enable(uint32_t dma_periph, dma_channel_enum channelx, ControlStatus newvalue);
- /* DMA FIFO status get */
- uint32_t dma_fifo_status_get(uint32_t dma_periph, dma_channel_enum channelx);
- /* flag and interrupt functions */
- /* check DMA flag is set or not */
- FlagStatus dma_flag_get(uint32_t dma_periph, dma_channel_enum channelx, uint32_t flag);
- /* clear DMA a channel flag */
- void dma_flag_clear(uint32_t dma_periph, dma_channel_enum channelx, uint32_t flag);
- /* check DMA flag is set or not */
- FlagStatus dma_interrupt_flag_get(uint32_t dma_periph, dma_channel_enum channelx, uint32_t interrupt);
- /* clear DMA a channel flag */
- void dma_interrupt_flag_clear(uint32_t dma_periph, dma_channel_enum channelx, uint32_t interrupt);
- /* enable DMA interrupt */
- void dma_interrupt_enable(uint32_t dma_periph, dma_channel_enum channelx, uint32_t source);
- /* disable DMA interrupt */
- void dma_interrupt_disable(uint32_t dma_periph, dma_channel_enum channelx, uint32_t source);
- #endif /* GD32F4XX_DMA_H */
|