单线双向模块_UART学习

2022.01.28

学习目标:最快的速度学习一个模块,同时懂得仿真的使用

该模块的意义就是,通过单线双向能够完成多位数据的传输,即实现并转串,这样可以节省IO资源,可以简化互联

如下图,MASTER和SLAVE之间通过单线连接,该单线实现数据的双向传输

转换为并行数据,给到模块内部使用

模块同时需要支持并行数据的位宽可调节,如下

引入一些基本的概念

波特率:每秒传输多少个bit,比如9600,则传输周期位1/9600,即多长周期传输一个bit的数据,1bit的时间大概是1/9600= 104us

帧格式,一帧数据的格式,比如电脑的串口,默认为8个数据位,和一个起始位,和一个终止位,也就是一帧数据位10bit,故1s可以发送960帧数据

串口使用异步通信,没有时钟的传输,接收器必须有一个自己的方法产生时钟,从而确定输入的数据

两端事先确定好通讯参数,线路空闲时,会发送1,发送器发送个0,代表开始发送数据,发送8位数据,发送完成之后发送停止位1

这是另一个例子,如果不确定时钟,怎么去解析这种数据呢?

比如以下,如果时钟是1.8432MHZ,则分16次就得到了115200HZ

相当于在当前的时钟下, 计数16次,产生所需的时钟 

解释了如果不使用标准时钟进行生成波特率时钟的话,误差的来源,会积累一个数据帧的误差,进行累积,越往后累积的越多,比如下面的计算累积了0.7us,但是一个停止位占了8.68us,很低,会采样不准么?

所谓的过采样,就是系统时钟会在这个数据段内采样多组数据,比如采样10组数据,肯定取多的那组

这种产生的时钟是有误差的,也可以很好的解释这个误差,能够降低这个误差么?引入方法2,解释如下:

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值