gd32DMA发送

#include"stdio.h"
#include"gd32f30x.h"
#include"keydiver.h"

   unsigned char data0[10]={1,2,3,4,5,6,7,8,9,0};
		unsigned char  data1[10]={0};
		volatile int dmasending=0;
					dma_parameter_struct dmatxcfg;

		dma_parameter_struct dmacfg;
		unsigned char* pdata=0;
		unsigned char data2[10]={0};
		
		void DMA0_Channel3_IRQHandler()
{
		
		if(dma_interrupt_flag_get(DMA0,DMA_CH3,DMA_INT_FLAG_FTF)){
			dma_interrupt_flag_clear(DMA0,DMA_CH3,DMA_INT_FLAG_FTF);
									dmasending=0;

		}
	
		
}
		void usartdmasend(unsigned char *pdata,int nlen)
		{
			while(dmasending);

			dmasending=1;

			dma_channel_disable(DMA0,DMA_CH3);
			dmatxcfg.memory_addr=(uint32_t)pdata;
			dmatxcfg.number=nlen;
			dma_init(DMA0,DMA_CH3,&dmatxcfg);
			dma_channel_enable(DMA0,DMA_CH3);
			
		
		}
		void usartdma()
		{
		rcu_periph_clock_enable(RCU_AF);
			rcu_periph_clock_enable(RCU_GPIOA);
			gpio_init(GPIOA,GPIO_MODE_AF_PP,GPIO_OSPEED_10MHZ,GPIO_PIN_9);
			rcu_periph_clock_enable(RCU_USART0);
			usart_deinit(USART0);
			usart_baudrate_set(USART0,115200);
			usart_parity_config(USART0,USART_PM_NONE);
			usart_word_length_set(USART0,USART_WL_8BIT);
			usart_stop_bit_set(USART0,USART_STB_1BIT);
			usart_transmit_config(USART0,USART_TRANSMIT_ENABLE);
			usart_dma_transmit_config(USART0,USART_DENT_ENABLE);
			usart_enable(USART0);
			rcu_periph_clock_enable(RCU_DMA0);
			dma_deinit(RCU_DMA0,DMA_CH3);
			 dmatxcfg.periph_addr  =USART0+0x04;//shift addrss (uint32_t)
       dmatxcfg.periph_width = DMA_PERIPHERAL_WIDTH_8BIT; 
       dmatxcfg.periph_inc   = DMA_PERIPH_INCREASE_DISABLE;
       //dmatxcfg.memory_addr  = (uint32_t)data1;
       dmatxcfg.memory_width = DMA_MEMORY_WIDTH_8BIT;
       dmatxcfg.memory_inc   = DMA_MEMORY_INCREASE_ENABLE;
       //dmatxcfg.number       = 10U;
       dmatxcfg.direction    = DMA_MEMORY_TO_PERIPHERAL;
       dmatxcfg.priority     = DMA_PRIORITY_LOW;
			dma_interrupt_enable(DMA0,DMA_CH3,DMA_INT_FTF);
			nvic_irq_enable(DMA0_Channel3_IRQn,2,2);
						dma_init(DMA0,DMA_CH3,&dmatxcfg);


		}
		

int main()
{
	usartdma();

	while(1){			usartdmasend((unsigned char*)123,3);
								

}
	
	
}

因为usart0的发送对应dma0的channel3,所以配置dma0的通道3,usart0的发送对应pa9,所以要打开pa9端口,之后配置波特率,校验位,停止位,字长,串口dma发送,配置dma中断,中断优先级,然后编写发送函数,一但进入函数那么sending置为1,先失能通道之后,内存地址改为pdata,这样就可以将pdata里的值发送出去,等到发送完成后进入中断标志,将sending置为0,这样dma就可以继续发送啦。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 确定DMA通道和USART外设 首先,我们需要确定使用的DMA通道和USART外设。在GD32的芯片中,USART有两个DMA通道,分别是DMA1通道4和DMA1通道5。我们需要根据实际情况选择一个可用的DMA通道和USART外设。 2. 配置USART外设 接下来,我们需要配置USART外设。首先,我们需要启用USART外设的DMA发送功能。我们可以使用USART_CTL1_REG的DMAT位来实现这一点。将DMAT位设置为1即可启用DMA发送功能。 另外,我们还需要配置USART的波特率、数据位、停止位等参数。这些参数需要根据实际情况进行配置。 3. 配置DMA传输参数 接下来,我们需要配置DMA传输参数。传输参数包括DMA通道、数据长度、数据方向等。我们需要将DMA的通道设置为之前选择的通道,并将数据长度设置为要发送的数据长度。数据方向需要设置为从内存到外设。 4. 配置DMA中断 最后,我们需要配置DMA中断。我们可以使用DMA_CTL_REG的TCIE位来启用传输完成中断。当DMA传输完成时,将会触发中断,并执行我们事先定义好的中断处理函数。 5. 启动DMA传输 配置完成后,我们可以启动DMA传输。启动传输后,DMA会自动将内存中的数据发送USART外设。当传输完成时,会触发中断。我们可以在中断处理函数中进行相应的处理,例如关闭DMA传输等。 下面是一个GD32串口DMA发送的示例代码: ``` #include "gd32f10x.h" /* 定义要发送的数据 */ uint8_t data[] = "Hello, World!"; void dma_config(void) { /* 选择DMA通道和USART外设 */ dma_parameter_struct dma_init_struct; dma_deinit(DMA1, DMA_CH4); dma_struct_para_init(&dma_init_struct); dma_init_struct.direction = DMA_MEMORY_TO_PERIPHERAL; dma_init_struct.memory_addr = (uint32_t)data; dma_init_struct.memory_inc = DMA_MEMORY_INCREASE_ENABLE; dma_init_struct.periph_addr = (uint32_t)&USART_DATA(USART0); dma_init_struct.periph_inc = DMA_PERIPH_INCREASE_DISABLE; dma_init_struct.memory_width = DMA_MEMORY_WIDTH_8BIT; dma_init_struct.periph_width = DMA_PERIPHERAL_WIDTH_8BIT; dma_init_struct.priority = DMA_PRIORITY_ULTRA_HIGH; dma_init(DMA1, DMA_CH4, &dma_init_struct); /* 配置DMA中断 */ nvic_irq_enable(DMA1_Channel4_IRQn, 0, 0); /* 启用USART外设的DMA发送功能 */ usart_dma_transmit_config(USART0, USART_DENT_ENABLE); } void usart_config(void) { usart_parameter_struct usart_init_struct; usart_struct_para_init(&usart_init_struct); /* 配置USART波特率、数据位、停止位等参数 */ usart_init_struct.baud_rate = 115200; usart_init_struct.word_length = USART_WL_8BIT; usart_init_struct.stop_bits = USART_SB_1BIT; usart_init_struct.parity = USART_PM_NONE; usart_init_struct.flow_control = USART_FC_NONE; usart_init(USART0, &usart_init_struct); } int main(void) { /* 初始化USARTDMA */ usart_config(); dma_config(); /* 启动DMA传输 */ dma_channel_enable(DMA1, DMA_CH4); while(1) { /* 主循环 */ } } void DMA1_Channel4_IRQHandler(void) { if(dma_interrupt_flag_get(DMA1, DMA_CH4, DMA_INT_FLAG_FTF)) { /* 关闭DMA传输 */ dma_channel_disable(DMA1, DMA_CH4); /* 清除中断标志位 */ dma_interrupt_flag_clear(DMA1, DMA_CH4, DMA_INT_FLAG_FTF); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值