OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3397|回复: 1

关于DMA的问题

[复制链接]

30

主题

59

帖子

0

精华

初级会员

Rank: 2

积分
178
金钱
178
注册时间
2015-8-29
在线时间
17 小时
发表于 2016-12-4 16:36:25 | 显示全部楼层 |阅读模式
1金钱
         uart2_init(9600);
        MYDMA_Config(DMA1_Channel7,(u32)&USART2->DR,(u32)SendBuff,(TEXT_LENTH+2)*100);//DMA1通道4,外设为串口1,存储器为SendBuff,长(TEXT_LENTH+2)*100.         
        while(1)
        {
                        USART2->DR=0X55;
                  USART_DMACmd(USART2,USART_DMAReq_Tx,ENABLE); //????1?DMA??        
                        MYDMA_Enable(DMA1_Channel7);//开始一次DMA传输!       
     }

MYDMA_Enable(DMA1_Channel7);意思是不是说可以开始一次完整的DMA传输。
但是要等到触发脉冲到来的时候才会发送数据啊,这里的触发脉冲是什么?是发送一个数据结束的标志位吗?
如将 USART_DMAReq_Tx 改为 USART_DMAReq_Rx ,是不是就是接受到一个数据,有一个触发脉冲啊


最佳答案

查看完整内容[请看2#楼]

不需要等待触发脉冲,触发信号来自USART,当USART->DR寄存器的数据发送完成后,会请求DMA传输新的数据过来,此过程完全硬件实现。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2016-12-4 16:36:26 | 显示全部楼层
不需要等待触发脉冲,触发信号来自USART,当USART->DR寄存器的数据发送完成后,会请求DMA传输新的数据过来,此过程完全硬件实现。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-7-11 03:18

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表