当前位置:首页 > 技术学院 > 技术前线
[导读]DS1302时钟模块通信原理(SPI总线)

学过SPI总线后,不难发现SPI总线通信时序与DS1302通信时序有相似之处。

然而DS1302模块却仅有三根线,事实上,DS1302的通信是SPI的变异种类,它采用了SPI的通信时序,但是通信的时候没有完全按照SPI的规则来,下面我们将逐步分析DS1302的变异SPI通信方式

首先来看DS1302单字节写入操作(图一):


然后我们再对比一下CPOL=0并且CPHA=0的情况下的SPI的操作时序(图二):


在两者的通信时序中,使能信号是相反的。对于通信写数据,都是在SCK的上升沿,从机进行采样,下降沿的时候,主机发送数据(为什么从机是在上升沿采样,请看下文注释1)。DS1302的时序里,单片机要预先写一个字节指令,指明要写入的寄存器的地址以及后续的操作是写操作,然后再写入一个字节的数据。

注释1:DS1302时序图时钟信号上的箭头是针对DS1302而言的,即:时钟模块在箭头进行数据采样或数据输出。同样,在非箭头处,主机(单片机)进行数据采样或数据输出。而上图时序图为写数据,即时钟模块接收数据,因此时钟模块在箭头处进行的是数据采样工作(接收单片机输出的数据)。单片机向外发送数据,因此主机在下降沿进行的是数据输出工作。

对于DS1302的单字节读操作,时序图如下:


需要注意的是:

一、DS1302的单字节读操作分为两步,第一步主机向从机写入地址(与上文中单字节写操作的时序图相同),第二步DS1302才开始向主机发送数据。观察第二步时序图中时钟信号上面的箭头可以发现,DS1302在下降沿向外传输数据(根据上文中对于箭头的解释,此时正在进行读操作,即DS1302向单片机发送数据,所以时钟模块此时进行的是数据传输工作)。那么在没有箭头的上升沿,单片机进行的则是数据采样工作。

二、我们的单片机没有标准的SPI接口,和I2C一样需要用IO口来模拟通信过程。在读DS1302的时候,理论上SPI是上升沿读取,但是我们的程序是用IO口模拟的,所以数据的读取和时钟沿的变化不可能同时了,必然就有一个先后顺序。通过实验发现,如果先读取IO线上的数据,再拉高SCLK产生上升沿,那么读到的数据一定是正确的,而颠倒顺序后数据就有可能出错。这个问题产生的原因还是在于DS1302的通信协议与标准SPI协议存在的差异造成的,如果是标准SPI的数据线,数据会一直保持到下一个周期的下降沿才会变化,所以读取数据和上升沿的先后顺序就无所谓了;但DS1302的IO线会在时钟上升沿后被DS1302释放,也就是撤销强推挽输出变为弱下拉状态,而此时在51单片机引脚内部上拉的作用下,IO线上的实际电平会慢慢上升,从而导致在上升沿产生后再读取IO数据的话就可能出错。因此这里的程序我们按照先读取IO数据,再拉高SCLK产生上升沿的顺序。

最后需要注意的是:只有在SCLK为低电平时,才能将CE置为高电平。因为SCLK连接的是单片机IO口,默认情况下为高电平。若CE置为高电平(置为高电平后DS1302开始工作)后将SCLK拉低,这相当于在时钟模块开始工作后,SCLK来了一个下降沿,这与时序图是不符合的。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

香港2022年7月7日 /美通社/ -- 寿康集团有限公司(“寿康集团”或“本公司”及其附属公司,统称“本集团”;股份代号:0575.HK)旗下全资附属公司、并以香港为基地的人工智能创新公司及衰老与长寿深层生物...

关键字: 时钟 VI GE EV

文章转自知乎[MIPI自学笔记],作者IEEE1364https://zhuanlan.zhihu.com/p/926820471 MIPI概述MIPI是MobileIndustryProcessorInterface的...

关键字: MIPI LAN 数据流 时钟

1、为设计执行综合时使用的各种设计约束是什么?1.1、创建时钟(频率、占空比)。1.2、定义输入端口的transition-time要求1.3、指定输出端口的负载值1.4、对于输入和输出,指定延迟值(输入延迟和输出延迟)...

关键字: 数字芯片 时钟 WIRE CK

如今,SoCs正变得越来越复杂,数据经常从一个时钟域传输到另一个时钟域。上图信号A由C1时钟域触发,被C2时钟域采样。根据这两个时钟之间的关系,在将数据从源时钟传输到目标时钟时,可能会出现不同类型的问题,并且这些问题的解...

关键字: 时钟 触发器 同步器 SETUP

本文主要介绍各种类型的跨时钟域问题。同步时钟是指具有已知相位和频率关系的时钟。这些时钟本质上是来自同一时钟源。根据相位和频率关系,可分为以下几类:具有相同频率和零相位差的时钟具有相同频率和固定相位差的时钟具有不同频率和可...

关键字: 异步 时钟 相位差 SETUP

跨时钟域验证可分为结构验证和功能验证两类。结构验证确保在需要的地方添加了适当的同步逻辑。功能验证确保已添加的逻辑实现了预期的功能。仅通过执行结构验证,就可以检测到许多CDC问题。这些检查比功能验证更简单、更快。因此,验证...

关键字: 时钟 数据传输 信号 TE

来源:射频百花谭规范很重要工作过的朋友肯定知道,公司里是很强调规范的,特别是对于大的设计(无论软件还是硬件),不按照规范走几乎是不可实现的。逻辑设计也是这样:如果不按规范做的话,过一个月后调试时发现有错,回头再看自己写的...

关键字: VERILOG 时钟 计数器 仿真验证

中断服务程序

关键字: 时钟 中断程序

首先通过按“校时、校分、校星期”等按键,校对好时间。 先检查时钟显示是否当前时间一致,如需重新校准,在按住“时钟”键的同时,分别按住“校星期”、“校时”、“校分”键,将时钟调到当前准确时间。

关键字: 自动开关定时器 时钟

出品21ic论坛qbwww网站:bbs.21ic.com做一个桌面时钟大家好,我是qbwww,今天我们来做一个桌面时钟。淘宝买的套件。首先呢,我们先看一下原理图,简单的了解一下连线方式。简单的了解了一下连线的方式呢,我们...

关键字: 时钟
关闭
关闭