野火电子论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 17077|回复: 1

关于串口 DR 寄存器

[复制链接]
发表于 2019-2-24 10:25:16 | 显示全部楼层 |阅读模式
本帖最后由 曹董董 于 2019-2-24 16:06 编辑

1. 请问这个 DR 寄存器会存储发送数据的起始位和停止位吗?还是说只会存储数据部分
2. 可不可以这样理解 TC, TXE 这两个位的含义就是说 TC 表示一帧数据发送完成, 但是并不表示移位寄存器空, 而在使用时这两个是不是没有区别, 还是说有的地方必须用哪个?
还有这个硬件机制是检测到 TXE 置位, 然后再把 DR 的数据转移到移位寄存器还是说移位寄存器移出一位数据 DR 就补一位数据?
3. 为什么做串口控制LED实验时不能使能接收中断?
回复

使用道具 举报

发表于 2019-2-24 22:14:31 | 显示全部楼层
本帖最后由 aozima 于 2019-2-24 22:15 编辑

1. 只会存储数据部分

2. T=transmission(这里特指发送),C=complete,E=empty.
TXE=DR空了(数据至少进入了shift寄存器,但不确定移完了)
TC=移位完成,且DR中也没有新数据(真发完了,包含TXE)

要发一串数据,查到TXE立刻塞下一个,全塞完后,要等到TC才真正发完。
如果是做485方向切换,不查TC可能最后的数据就丢了。

STM32的UART没有FIFO,或理解为只有1个字的fifo,
如果FIFO深度更大的芯片,这块需要更加深入的理解。
回复 支持 反对

使用道具 举报

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

本版积分规则

联系站长|手机版|野火电子官网|野火淘宝店铺|野火电子论坛 ( 粤ICP备14069197号 ) 大学生ARM嵌入式2群

GMT+8, 2025-12-6 11:52 , Processed in 0.048991 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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