OpenEdv-开源电子网

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

关于DMA的问题

[复制链接]

12

主题

38

帖子

0

精华

初级会员

Rank: 2

积分
106
金钱
106
注册时间
2014-10-23
在线时间
0 小时
发表于 2015-4-11 18:56:08 | 显示全部楼层 |阅读模式
5金钱
在使用串口DMA发送的时候,我在参考手册P535上找到这么一句话:“使用DMA进行发送,可以通过设置USART_CR3寄存器上的DMAT位激活。当TXE位被置为’1’时,DMA就从指定的SRAM区传送数据到USART_DR寄存器“。从USARTx->SR中可以看到,TXE是串口数据寄存器为空的标志位,根据上面这句话的意思,就是当数据缓冲区为空(TEX=1)的时候,DMA就从指定的SRAM区传送数据USART_DR寄存器。当我们写入一个数据到USART_DR中的时候TEX=0,读取USART_DR的之后TEX=1,但是我们在DMA试验中貌似没有进行读USART_DR寄存器啊,也就是一旦写入第一数据之后TEX=0,没有使TEX=1,为什么还可以连续发送5000多个数据呢?

不知道我描述清楚没有,请大家不吝赐教,谢谢

最佳答案

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

TXE 是硬件自动控制的。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

58

主题

6294

帖子

1

精华

资深版主

Rank: 8Rank: 8

积分
11557
金钱
11557
注册时间
2014-4-1
在线时间
1318 小时
发表于 2015-4-11 18:56:09 | 显示全部楼层
TXE 是硬件自动控制的。
回复

使用道具 举报

12

主题

38

帖子

0

精华

初级会员

Rank: 2

积分
106
金钱
106
注册时间
2014-10-23
在线时间
0 小时
 楼主| 发表于 2015-4-12 10:53:15 | 显示全部楼层
回复【2楼】xuande:
---------------------------------
谢谢你
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-23 22:30

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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