OpenEdv-开源电子网

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

STM32F407的串口的TDR与RDR

[复制链接]

1

主题

4

帖子

0

精华

新手入门

积分
9
金钱
9
注册时间
2021-3-17
在线时间
1 小时
发表于 2022-2-9 14:28:14 | 显示全部楼层 |阅读模式
1金钱
STM32F407的串口框图

图中发送与接收都有一个对应的寄存器,但是只有一个寄存器DR。
捕获.JPG
上文说该data register由TDR与RDR组成,不知道是如何组成的,理论上可用的只有Bit[8:0]

查阅了一些材料,说是朝寄存器DR里面写数据就是TDR,读DR里面的数据就是接收数据。关键问题在于,USART为全双工通讯,如果串口在某一时刻同时收发数据,那这个DR寄存器如何工作,分时吗。如果分时的话,是硬件实现的吗,还是说软件里面用了一些策略。

最佳答案

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

发送数据的同时接受到串口数据好像是没有冲突的,TDR和RDR这两个寄存器好像是硬件实现的。就是你第二个图圈着的。就是你去DR寄存器读数据的时候才会从RDR输出到DR寄存器里。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

4

主题

896

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4305
金钱
4305
注册时间
2019-9-4
在线时间
896 小时
发表于 2022-2-9 14:28:15 | 显示全部楼层
发送数据的同时接受到串口数据好像是没有冲突的,TDR和RDR这两个寄存器好像是硬件实现的。就是你第二个图圈着的。就是你去DR寄存器读数据的时候才会从RDR输出到DR寄存器里。
回复

使用道具 举报

1

主题

4

帖子

0

精华

新手入门

积分
9
金钱
9
注册时间
2021-3-17
在线时间
1 小时
 楼主| 发表于 2022-2-9 14:30:18 | 显示全部楼层
捕获.JPG
第一张图漏掉了补上
回复

使用道具 举报

1

主题

4

帖子

0

精华

新手入门

积分
9
金钱
9
注册时间
2021-3-17
在线时间
1 小时
 楼主| 发表于 2022-2-9 15:10:44 | 显示全部楼层
即使在物理上DR是两个寄存器,但是他们的地址一样,这让软件咋操作,很奇怪。
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165371
金钱
165371
注册时间
2010-12-1
在线时间
2110 小时
发表于 2022-2-9 23:20:05 | 显示全部楼层
有啥奇怪的,硬件帮你选择好了。
读就是读RDR
写就是写TDR
一点都不奇怪啊。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-2-26 02:52

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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