CN105227376A - Spi长距离通信传输中校正时延的方法及系统 - Google Patents

Spi长距离通信传输中校正时延的方法及系统 Download PDF

Info

Publication number
CN105227376A
CN105227376A CN201510705343.2A CN201510705343A CN105227376A CN 105227376 A CN105227376 A CN 105227376A CN 201510705343 A CN201510705343 A CN 201510705343A CN 105227376 A CN105227376 A CN 105227376A
Authority
CN
China
Prior art keywords
data
cpld
algorithm unit
unit
spi interface
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN201510705343.2A
Other languages
English (en)
Other versions
CN105227376B (zh
Inventor
陈奎
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Huzhou YingLie Intellectual Property Operation Co.,Ltd.
Original Assignee
Shanghai Feixun Data Communication Technology Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Shanghai Feixun Data Communication Technology Co Ltd filed Critical Shanghai Feixun Data Communication Technology Co Ltd
Priority to CN201510705343.2A priority Critical patent/CN105227376B/zh
Publication of CN105227376A publication Critical patent/CN105227376A/zh
Application granted granted Critical
Publication of CN105227376B publication Critical patent/CN105227376B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Landscapes

  • Synchronisation In Digital Transmission Systems (AREA)

Abstract

本发明提供一种SPI长距离通信传输中校正时延的方法及系统,该系统包括依次通信连接的主控SPI接口单元、第一CPLD算法单元、背板连接单元、第二CPLD算法单元、以及业务SPI接口单元;所述第一CPLD算法单元用于通过发送特定前导码数据和接收经回传的特定前导码数据计算得出所述背板连接单元中传输数据的数据延时时间,将所述数据延时时间发送至所述主控SPI接口单元;所述第二CPLD算法单元用于接收所述第一CPLD算法单元发送的所述特定前导码数据并回传给所述第一CPLD算法单元。本发明通过CPLD算法实现对数据的自动时延计算而进行采样数据的校正,解决因SPI总线在长距离走线传输过程中所带来的时延问题。

Description

SPI长距离通信传输中校正时延的方法及系统
技术领域
本发明涉及数据传输领域,特别是涉及一种SPI长距离通信传输中校正时延的方法及系统。
背景技术
OLT(OpticalLineTerminal,光缆终端设备)设备的常规产品形态都是采用背板设计,主控通过SPI(SerialPeripheralInterface,串行外设接口)的接口总线实现业务板的配置信息的读取和设定。而OLT设备主控和业务之间的管理通道的走线很长,当主控和背板走线过长时,传输线的延时会增加很多,主控的数据访问因为传输延时就会出现数据采样严重失真的现象。现有的常规设计中只是在总线两边增加数据的缓冲来增加总线的驱动能力以实现总线的长距离传输,但是却不能解决由于长距离走线传输所造成的时延而导致主控板卡在接收业务板卡回传数据时不能正确采样的问题。
发明内容
鉴于以上所述现有技术的缺点,本发明的目的在于提供一种SPI长距离通信传输中校正时延的方法及系统,用于解决现有的OLT设备因走线长而引起的传输中产生延时造成的数据采样失真的问题。
为实现上述目的及其他相关目的,本发明提供一种SPI长距离通信传输中校正时延的方法,用于主控SPI接口和业务SPI接口之间的长距离走线通信,所述时延校正方法包括:
提供第一CPLD算法单元,将所述第一CPLD算法单元通信连接于所述主控SPI接口和所述长距离走线之间;
提供第二CPLD算法单元,将所述第二CPLD算法单元通信连接于所述业务SPI接口和所述长距离走线之间;
由所述第一CPLD算法单元发送特定前导码数据经长距离走线传输至所述第二CPLD算法单元;
由所述第二CPLD算法单元接收所述特定前导码数据并经所述长距离走线将接收的所述特定前导码数据回传至所述第一CPLD算法单元;
由所述第一CPLD算法单元计算回传的所述特定前导码数据在传输中的数据延时时间;以及
由所述第一CPLD算法单元将计算得出的所述数据延时时间发送给所述主控SPI接口,以使得所述主控SPI接口在接收来自所述业务SPI接口传送的数据时,将时钟自动延时对应所述数据延时时间的时间长度之后再进行数据采样。
优选地,由所述第一CPLD算法单元计算回传的所述特定前导码数据在传输中的数据延时时间,包括:
设定一时延长度,所述第一CPLD算法单元根据所述时延长度接收经回传的所述特定前导码数据;
由所述第一CPLD算法单元比较发送的特定前导码数据与接收的经回传的所述特定前导码数据,若比较结果相同则所述数据延时时间为所述时延长度的一半,若比较结果不同则增加时延长度并重复发送特定前导码数据再进行比较,直至比较结果相同为止。
优选地,当比较结果不同时,增加后的时延长度为当前的时延长度和设定的时延长度之和。
优选地,由所述第一CPLD算法单元发送特定前导码数据经长距离走线传输至所述第二CPLD算法单元之前,还包括:
由所述第一CPLD算法单元从所述主控SPI接口处获取时钟作为参考时钟而后阻塞所述第一CPLD算法单元与所述主控SPI接口之间的数据通信;
由所述第一CPLD算法单元根据所述参考时钟形成需发送的特定前导码数据。
优选地,还包括:
提供第一数据缓存器,将所述第一数据缓存器通信连接于所述第一CPLD算法单元和所述长距离走线之间,
提供第二数据缓存器,将所述第二数据缓存器通信连接于所述第二CPLD算法单元和所述长距离走线之间;
通过所述第一数据缓存器和所述第二数据缓存器为需经所述长距离走线传输的数据增强信号的驱动能力。
本发明还提供了一种SPI长距离通信传输中校正时延的系统,包括主控SPI接口单元、与所述主控SPI接口单元通信连接的第一CPLD算法单元、与所述第一CPLD算法单元通信连接的背板连接单元、与所述背板连接单元通信连接的第二CPLD算法单元、以及与所述CPLD算法单元通信连接的业务SPI接口单元;
所述主控SPI接口单元和所述业务SPI接口单元通过所述背板连接单元传输数据以进行通信;
所述第一CPLD算法单元用于通过发送特定前导码数据和接收经回传的特定前导码数据计算得出所述背板连接单元中传输数据的数据延时时间,所述第一CPLD算法单元将所述数据延时时间发送至所述主控SPI接口单元;
所述第二CPLD算法单元用于接收所述第一CPLD算法单元发送的所述特定前导码数据并回传给所述第一CPLD算法单元。
优选地,所述第一CPLD算法单元包括检测时钟模块、与检测时钟模块连接的前导码数据生成模块、以及与所述前导码数据生成模块连接的解析回环码模块;
所述检测时钟模块用于检测所述主控SPI接口单元的时钟作为参考时钟;
所述前导码数据生成模块用于根据所述参考时钟生成所述特定前导码数据并阻塞所述主控SPI接口单元和所述第一CPLD算法之间的数据通信;
所述解析回环码模块用于发送所述特定前导码数据和通过根据设定的时延长度接收所述第二CPLD算法单元回传的所述特定前导码数据,并比较发送的所述特定前导码数据和接收的经回传的所述特定前导码数据,若比较结果相同计算得出所述数据延时时间为所述时延长度的一半,若比较结果不同则增加时延长度并再次发送特定前导码数据而进行比较,直至比较结果相同为止。
优选地,所述解析回环码模块每次增加的时延长度为当前的时延长度和设定的时延长度之和。
优选地,所述第二CPLD算法单元包括检析数据模块、与所述检析数据模块连接的判断模块、与所述判断模块连接数据透传模块、以及与所述判断模块连接的回环模块;
所述检析数据模块用于检析接收的数据并发送给所述判断模块;
所述判断模块用于判断所述检析数据模块发送的数据是否为特定前导码数据,若是则发送给所述回环模块,若否则发送给所述透传模块;
所述透传模块用于将接收的数据发送给所述业务SPI接口单元;
所述回环模块用于将接收的所述特定前导码数据回传给所述第一CPLD算法单元。
优选地,还包括连接于所述第一CPLD算法单元与所述背板连接单元之间的第一数据缓存器和连接于所述第二CPLD算法单元与所述背板连接单元之间的第二数据缓存器,所述第一数据缓存器和所述第二数据缓存器用于为需经所述背板连接单元传输的数据增强信号的驱动能力。
如上所述,本发明的一种SPI长距离通信传输中校正时延的方法及系统,具有以下有益效果:
本发明的SPI长距离通信传输中校正时延的方法及系统,通过CPLD算法实现对数据的自动时延计算而进行采样数据的校正,解决因SPI总线在长距离走线传输过程中所带来的时延问题。
附图说明
图1显示为本发明SPI长距离通信传输中校正时延的系统的结构框图。
图2显示为本发明SPI长距离通信传输中校正时延的系统中第一CPLD算法单元的结构框图。
图3显示为本发明SPI长距离通信传输中校正时延的系统中第二CPLD算法单元的结构框图。
图4显示为本发明SPI长距离通信传输中校正时延的方法的流程图。
图5显示为本发明SPI长距离通信传输中校正时延的方法中第一CPLD算法单元的流程图。
图6显示为本发明SPI长距离通信传输中校正时延的方法中第二CPLD算法单元的流程图。
元件标号说明
11主控SPI接口单元
12业务SPI接口单元
13第一CPLD算法单元
14第二CPLD算法单元
15背板连接单元
16第一数据缓存器
17第二数据缓存器
131检测时钟模块
132前导码生成模块
133解析回环码模块
141检析数据模块
142判断模块
143透传模块
144回环模块
S21~S26步骤
S31~S37步骤
S41~S44步骤
具体实施方式
以下通过特定的具体实例说明本发明的实施方式,本领域技术人员可由本说明书所揭露的内容轻易地了解本发明的其他优点与功效。本发明还可以通过另外不同的具体实施方式加以实施或应用,本说明书中的各项细节也可以基于不同观点与应用,在没有背离本发明的精神下进行各种修饰或改变。需说明的是,在不冲突的情况下,以下实施例及实施例中的特征可以相互组合。
需要说明的是,以下实施例中所提供的图示仅以示意方式说明本发明的基本构想,遂图式中仅显示与本发明中有关的组件而非按照实际实施时的组件数目、形状及尺寸绘制,其实际实施时各组件的型态、数量及比例可为一种随意的改变,且其组件布局型态也可能更为复杂。
请参阅图1,本发明提供一种SPI长距离通信传输中校正时延的方法及系统,用于解决因为SPI总线在长距离走线传输过程中带来的时延问题。在SPI总线的数据采样的参考时钟为主控SPI接口的时钟,所以在数据从主控SPI接口发送到业务SPI接口时由于数据和时钟同时传输,两者到达业务SPI接口时延时时相同的,所以不会导致数据采样错误的状况,而当数据从业务SPI接口到主控SPI接口时只有数据传输,时钟依然是参考主控SPI接口的时钟,也就是说数据有延时,而时钟没有延时,这时就会导致采样失真,且走线越长延时越严重,采样就越失真,本发明就是要解决这个问题。本发明在主控SPI接口和业务SPI接口处设置CPLD(ComplexProgrammableLogicDevice,复杂可编程逻辑器件)算法单元,通过CPLD算法单元计算出长距离走线上传输数据的数据延时时间,并将该数据延时时间告知主控SPI接口,当主控SPI接口接收业务SPI接口发送的数据时,将时钟延时由长走线传输导致的数据延时时间来采样接收数据,以避免由于长走线导致信号延时而无法正常采样的情况。下面结合附图对本发明SPI长距离通信传输中校正时延的系统进行说明。
如图1所示,本发明SPI长距离通信传输中校正时延的系统包括主控SPI接口单元11、业务SPI接口单元12、第一CPLD算法单元13、第二CPLD算法单元14、背板连接单元15、第一数据缓存器16、以及第二数据缓存器17,其中主控SPI接口单元11与第一CPLD算法单元13通信连接,第一CPLD算法单元13与背板连接单元15通信连接,背板连接单元15与第二CPLD算法单元14通信连接,第二CPLD算法单元14与业务SPI接口单元12通信连接,第一数据缓存器16连接于第一CPLD算法单元13和背板连接单元15之间,第二数据缓存器17连接于第二CPLD算法单元14和背板连接单元15之间。主控SPI接口单元11设于主控板上,主控板通过主控SPI接口单元11接收和发送数据。业务SPI接口单元设于业务板上,业务板通过业务SPI接口单元12接收和发送数据。主控SPI接口单元11和业务SPI接口单元12通过背板连接单元15传输数据以进行通信,该背板连接单元15的走线很长,且走线越长信号的时延就会越大,为解决在背板连接单元15的传输过程中产生的时延问题,通过第一CPLD算法单元13计算出数据时延时间,再将数据时延时间告知主控SPI接口单元11即可,这样主控SPI接口单元11将时钟延时到数据时延时间再接收数据,就避免了数据时延造成的信号失真。
第一CPLD算法单元13发送特定前导码数据经背板连接单元15传输至第二CPLD算法单元14,该第二CPLD算法单元14将接收的特定前导码数据再经背板连接单元15回传至第一CPLD算法单元13,该第一CPLD算法单元13通过发送特定前导码数据和接收经回传的特定前导码数据计算得出背板连接单元15中的传输数据的数据延时时间。如图2所示,该第一CPLD算法单元13包括检测时钟模块131、前导码数据生成模块132、以及解析回环码模块133,检测时钟模块131与前导码数据生成模块132连接,前导码数据生成模块132与解析回环码模块133连接。该检测时钟模块131用于检测主控SPI接口单元的时钟作为参考时钟,将该参考时钟发送给前导码数据生成模块132;前导码数据生成模块132根据参考时钟生成特定前导码数据,前导码数据生成模块132阻塞第一CPLD算法单元13和主控SPI接口11之间的数据通信,以确保在传输特定前导码数据时无其他数据通信的干扰。前导码数据生成模块132将参考时钟和生成的前导码数据发送给解析回环码模块133,该解析回环码模块133用于发送该特定前导码数据给第二CPLD算法单元14,再根据设定的时延长度接收第二CPLD算法单元14回传的特定前导码数据,解析回环码模块133比较发送的特定前导码数据和接收的经回传的特定前导码数据,若比较结果相同,即两个数据一样,则计算得出数据延时时间为设定的时延长度的一半,这时取消第一CPLD算法单元13和主控SPI接口11之间的数据通信的阻塞状态,将数据时延时间告知主控SPI接口11;若比较结果不相同,即两个数据不一样,则增加时延长度并重复发送特定前导码数据,再进行比较,直到比较结果相同为止。
其中设定的时延长度根据实际情况进行选定,比如设定时延长度为参考时钟的1/10。每次增加的时延长度为当前的时延长度和设定的时延长度之和。以时延长度为参考时钟的1/10为例,第一次比较时的比较结果不同,增加一次相同的时延长度,也就是增加一次参考时钟的1/10,此时的时延长度为参考时钟的1/5。
如图3所示,第二CPLD算法单元14包括检析数据模块141、判断模块142、透传模块143、以及回环模块144,其中检析数据模块141与判断模块142连接,判断模块142与透传模块143和回环模块144连接,检析数据模块141用于检析接收的数据并发送给判断模块142进行判断;判断模块142用于判断检析数据模块141检析的数据是否为特定前导码数据,若是特定前导码数据则发送给回环模块144,通过回环模块144将特定前导码数据发送给第一CPLD算法单元,若不是特定前导码数据则发送给透传模块143,通过透传模块143将数据发送给业务SPI接口单元12。第二CPLD算法单元14中包括了两种模式,一种是回环模式通过回环模块实现,另一种是透传模式通过透传模块实现,设定为回环模式时,将接收到的特定前导码数据直接回传给第一CPLD算法单元,不往业务SPI接口单元12传输,设定为透传模式时,将接收到的数据传输给业务SPI接口单元12,以完成正常的通信。
第一数据缓存器16和第二数据缓存器17用于为需经背板连接单元15传输的数据增强信号的驱动能力,使得数据能够实现背板设计的长线传输,该第一数据缓存器16和第二数据缓存器17虽然增加了信号的驱动能力,但是不能避免信号的时延。
本发明的SPI长距离通信传输中校正时延的系统通过设置第一CPLD算法单元13和第二CPLD算法单元14而计算出背板连接单元15的数据时延时间,解决长距离走线通信带来的时延问题,虽然该第一CPLD算法单元13计算的数据时延时间是在第一CPLD算法单元13和第二CPLD算法单元14之间的走线通信距离,但是由于第一CPLD算法单元13和主控SPI接口单元11之间的走线距离很短,第二CPLD算法单元14和业务SPI接口单元12之间的走线距离也很短,均可忽略其所带来的时延,所以,本发明SPI长距离通信传输中校正时延的系统具有较高的校正时延的效果,且能够实现自动校正时延。
下面对本发明SPI长距离通信传输中校正时延的方法进行说明。
本发明SPI长距离通信传输中校正时延的方法,适用于主控SPI接口和业务SPI接口之间的长距离走线通信,以解决长距离走线通信中产生时延的问题,能够实现自动校正时延。如图4所示,本发明SPI长距离通信传输中校正时延的方法包括如下步骤:
执行步骤S21,将第一CPLD算法单元通信连接于主控SPI接口和长距离走线之间。通过第一CPLD算法单元计算长距离走线在传输中的数据时延时间。该第一CPLD算法单元还为主控SPI接口传输数据以进行数据通信。接着执行步骤S22。
执行步骤S22,将第二CPLD算法单元通信连接于业务SPI接口和长距离走线之间。利用第二CPLD算法单元配合第一CPLD算法单元进行数据通信,以使得第一CPLD算法单元能够计算出长距离走线在传输中的数据时延时间。该第二CPLD算法单元还用于为业务SPI接口传输数据以进行数据通信。接着执行步骤S23。
执行步骤S23,由第一CPLD算法单元发送特定前导码数据经长距离走线传输至第二CPLD算法单元。该第一CPLD算法单元先获取主控SPI接口处的时钟,将该时钟作为参考时钟,然后阻塞第一CPLD算法单元和主控SPI接口之间的数据通信,之后根据参考时钟形成特定前导码数据而发送该特定前导码数据至第二CPLD算法单元。在发送特定前导码数据之前将与主控SPI接口之间的通信阻塞是为了防止主控SPI接口发送数据干扰到特定前导码数据的传输。接着执行步骤S24。
执行步骤S24,由第二CPLD算法单元将接收的特定前导码数据回传至第一CPLD算法单元。该第二CPLD算法单元经长距离走线回传接收到的特定前导码数据。第二CPLD算法单元再接收到数据后对数据进行判断,若接收的数据是特定前导码数据则将该数据回传给第一CPLD算法单元,若数据不是特定前导码数据则将数据透传给业务SPI接口。接着执行步骤S25。
执行步骤S25,由第一CPLD算法单元计算特定前导码数据在传输中的数据延时时间。该第一CPLD算法单元根据发送的特定前导码数据和接收经回传的特定前导码数据计算数据延时时间,具体为,第一CPLD算法单元设定一时延长度,如将该时延长度设定为参考时钟的1/10,然后根据该时延长度接收经回传的特定前导码数据,然后第一CPLD算法单元进行比较,比较发送的特定前导码数据与接收的经回传的特定前导码数据是否相同,若比较结果相同,则所要计算的数据延时时间为时延长度的一半,若比较结果不同则增加时延长度并重复发送特定前导码数据再进行比较,直至该比较结果相同为止。其中的增加时延长度,增加后的时延长度为当前的时延长度和设定的时延长度之和,也就是每次增加一次相同的时延长度的时间。接着执行步骤S26。
执行步骤S26,由第一CPLD算法单元将计算得出的数据延时时间发送至主控SPI接口。第一CPLD算法单元计算得出数据延时时间后将消除与主控SPI接口之间的通信连接的阻塞状态,并将得出的数据延时时间告知主控SPI接口所在的主控板,这样主控板在接收数据时,将时钟自动延时对应的数据延时时间的时间长度在进行数据采样,有效地避免了延时带来的数据失真。
为确保数据能够在长距离走线上传输通信,添加为数据提供增强驱动能力的数据缓存器,具体地,提供第一数据缓存器,将该第一数据缓存器通信连接于第一CPLD算法单元和长距离走线之间,为要经长距离走线传输的数据增强信号的驱动能力,使得数据能够实现背板设计的长线传输。提供第二数据缓存器,将该第二数据缓存器通信连接于第二CPLD算法单元和长距离走线之间,为要经过长距离走线传输的数据增强信号的驱动能力。
主控SPI接口为主控板上的接口,用于接收和发送数据,业务SPI接口为业务板上的接口,也用于接收和发送数据,主控板和业务板之间的数据通信通过长距离走线进行传输,主控板和业务板之间的数据通信以主控板的时钟为参考时钟,数据从主控板的主控SPI接口发送到业务板的业务SPI接口时,由于数据和时钟同步传输,两者到达业务SPI接口的时延相同,所以不会导致数据采样错误的状况。然而当数据从业务板的业务SPI接口到主控SPI接口时只有数据传输,因为时钟依然是以主控板的时钟为参考时钟,这时数据有时延,而时钟没有时延,这样再以参考时钟为标准进行数据的接收时,会导致采样失真,且走线越长延时越严重,本发明采用第一CPLD算法单元,在主控SPI接口和业务SPI接口传输数据之前,将主控SPI接口与第一CPLD算法单元的通信连接阻塞,然后由第一CPLD算法单元发送特定前导码数据,再接收回传的特定前导码数据,以计算出该走线的数据延时时间,然后再将主控SPI接口与第一CPLD算法单元的通信连接打开,将数据延时时间告知主控板,这样主控SPI接口在接收数据时,将时钟延时至数据延时时间的长度进行数据采样,就有效地解决了时延的问题,本发明的方法实现了通信中自动校正时延。
如图5所示,下面对第一CPLD算法单元的执行流程进行说明。
执行步骤S31,检测主控SPI接口的时钟频率。第一CPLD算法单元通过与主控SPI接口之间的通信连接,检测主控SPI接口的时钟信号作为参考时钟。因为在主控板和业务板之间实际通信时也是以主控板的时钟为参考时钟的,这样以主控SPI接口的时钟为参考时钟计算出的数据延时时间更加准确。接着执行步骤S32。
执行步骤S32,产生特定前导码数据。第一CPLD算法单元生成特定前导码数据,该特定前导码数据具有特定的标识,以便第二CPLD算法单元能够识别并且回传。接着执行步骤S33和执行步骤S34。
执行步骤S33,阻塞主控SPI接口与第一CPLD算法单元支架的数据通信,将第一CPLD算法单元和主控SPI接口之间的通道设定为阻塞态,防止数据的流通,以避免主控SPI接口发送的数据影响到特定前导码数据。
执行步骤S34,CPLD解析回环码流信息,比较发送的特定前导码数据与接收的经回传的特定前导码数据是否相同。第一CPLD算法单元将生成的特定前导码数据经长距离走线发送至第二CPLD算法单元,该第二CPLD算法单元对接收到的数据进行识别判断,判断为特定前导码数据后将该特定前导码数据回传给第一CPLD算法单元,该第一CPLD算法单元设定一个时延长度,根据该时延长度接收回传的特定前导码数据并解析,然后将该接收的经回传的数据与发送的特定前导码数据进行比较,两个数据相同,则执行步骤S35,若不同则执行步骤S36。
执行步骤S35,设定数据延时时间。数据延时时间为时延长度的一半。接着执行步骤S37。
执行步骤S36,增加设定的时延长度。增加一次相同延时长度,增加后的延时长度为当前的延时长度与设定的延时长度之和,然后接着执行步骤S32重新生成特定前导码数据,接着执行步骤S34重复进行发送、接收和比较。
执行步骤S37,打开第一CPLD算法单元与主控SPI接口之间的数据通信,将数据延时时间告知主控SPI接口。
在计算数据延时时间时,计算的走线长度为第一CPLD算法单元和第二CPLD算法单元之间的长度,而在主控板和业务板之间通信的走线长度为主控SPI接口和业务SPI接口之间的长度,由于第一CPLD算法单元与主控SPI接口之间的距离和第二CPLD算法单元与业务SPI接口之间的长度较短,其中的时延可以忽略不计,并不影响本发明中计算出的数据延时时间的精确性。
如图6所示,下面对第二CPLD算法单元的执行流程进行说明。该第二CPLD算法单元具有两个模式,一个是回环模式,另一个是透传模式,具体如下:
执行步骤S41,检析数据包,第二CPLD算法单元对接收到的数据进行检析,接着执行步骤S42。
执行步骤S42,码流是否为前导码,对检析的数据包进行判断,判断该数据是否为特定前导码数据,若是则执行步骤S43,若不是则执行步骤S44。
执行步骤S43,设定回环模式,将特定前导码数据回传给第一CPLD算法单元,此时第二CPLD算法单元设定为回环模式,即不往业务SPI接口传输数据,而是将特定前导码数据直接回传给第一CPLD算法单元用来测定数据延时时间。
执行步骤S44,数据透传,此时第二CPLD算法单元设定为透传模式,将数据传输到业务SPI接口,完成正常通信。在确定好数据延时时间后,第二CPLD算法单元就取消回环模式,设定为透传模式。
综上所述,本发明SPI长距离通信传输中校正时延的方法及系统,通过CPLD算法单元计算通信传输中的数据延时时间,实现对数据的自动时延计算而进行采样数据的校正,来解决因为SPI总线在长距离走线传输过程中所带来的时延问题。所以,本发明有效克服了现有技术中的种种缺点而具高度产业利用价值。
上述实施例仅例示性说明本发明的原理及其功效,而非用于限制本发明。任何熟悉此技术的人士皆可在不违背本发明的精神及范畴下,对上述实施例进行修饰或改变。因此,举凡所属技术领域中具有通常知识者在未脱离本发明所揭示的精神与技术思想下所完成的一切等效修饰或改变,仍应由本发明的权利要求所涵盖。

Claims (10)

1.一种SPI长距离通信传输中校正时延的方法,用于主控SPI接口和业务SPI接口之间的长距离走线通信,其特征在于,所述时延校正方法包括:
提供第一CPLD算法单元,将所述第一CPLD算法单元通信连接于所述主控SPI接口和所述长距离走线之间;
提供第二CPLD算法单元,将所述第二CPLD算法单元通信连接于所述业务SPI接口和所述长距离走线之间;
由所述第一CPLD算法单元发送特定前导码数据经长距离走线传输至所述第二CPLD算法单元;
由所述第二CPLD算法单元接收所述特定前导码数据并经所述长距离走线将接收的所述特定前导码数据回传至所述第一CPLD算法单元;
由所述第一CPLD算法单元计算回传的所述特定前导码数据在传输中的数据延时时间;以及
由所述第一CPLD算法单元将计算得出的所述数据延时时间发送给所述主控SPI接口,以使得所述主控SPI接口在接收来自所述业务SPI接口传送的数据时,将时钟自动延时对应所述数据延时时间的时间长度之后再进行数据采样。
2.如权利要求1所述的SPI长距离通信传输中校正时延的方法,其特征在于,由所述第一CPLD算法单元计算回传的所述特定前导码数据在传输中的数据延时时间,包括:
设定一时延长度,所述第一CPLD算法单元根据所述时延长度接收经回传的所述特定前导码数据;
由所述第一CPLD算法单元比较发送的特定前导码数据与接收的经回传的所述特定前导码数据,若比较结果相同则所述数据延时时间为所述时延长度的一半,若比较结果不同则增加时延长度并重复发送特定前导码数据再进行比较,直至比较结果相同为止。
3.如权利要求2所述的SPI长距离通信传输中校正时延的方法,其特征在于,当比较结果不同时,增加后的时延长度为当前的时延长度和设定的时延长度之和。
4.如权利要求1或2所述的SPI长距离通信传输中校正时延的方法,其特征在于,由所述第一CPLD算法单元发送特定前导码数据经长距离走线传输至所述第二CPLD算法单元之前,还包括:
由所述第一CPLD算法单元从所述主控SPI接口处获取时钟作为参考时钟而后阻塞所述第一CPLD算法单元与所述主控SPI接口之间的数据通信;
由所述第一CPLD算法单元根据所述参考时钟形成需发送的特定前导码数据。
5.如权利要求1所述的SPI长距离通信传输中校正时延的方法,其特征在于,还包括:
提供第一数据缓存器,将所述第一数据缓存器通信连接于所述第一CPLD算法单元和所述长距离走线之间,
提供第二数据缓存器,将所述第二数据缓存器通信连接于所述第二CPLD算法单元和所述长距离走线之间;
通过所述第一数据缓存器和所述第二数据缓存器为需经所述长距离走线传输的数据增强信号的驱动能力。
6.一种SPI长距离通信传输中校正时延的系统,其特征在于,包括主控SPI接口单元、与所述主控SPI接口单元通信连接的第一CPLD算法单元、与所述第一CPLD算法单元通信连接的背板连接单元、与所述背板连接单元通信连接的第二CPLD算法单元、以及与所述CPLD算法单元通信连接的业务SPI接口单元;
所述主控SPI接口单元和所述业务SPI接口单元通过所述背板连接单元传输数据以进行通信;
所述第一CPLD算法单元用于通过发送特定前导码数据和接收经回传的特定前导码数据计算得出所述背板连接单元中传输数据的数据延时时间,所述第一CPLD算法单元将所述数据延时时间发送至所述主控SPI接口单元;
所述第二CPLD算法单元用于接收所述第一CPLD算法单元发送的所述特定前导码数据并回传给所述第一CPLD算法单元。
7.如权利要求6所述的SPI长距离通信传输中校正时延的系统,其特征在于,所述第一CPLD算法单元包括检测时钟模块、与检测时钟模块连接的前导码数据生成模块、以及与所述前导码数据生成模块连接的解析回环码模块;
所述检测时钟模块用于检测所述主控SPI接口单元的时钟作为参考时钟;
所述前导码数据生成模块用于根据所述参考时钟生成所述特定前导码数据并阻塞所述主控SPI接口单元和所述第一CPLD算法之间的数据通信;
所述解析回环码模块用于发送所述特定前导码数据和通过根据设定的时延长度接收所述第二CPLD算法单元回传的所述特定前导码数据,并比较发送的所述特定前导码数据和接收的经回传的所述特定前导码数据,若比较结果相同计算得出所述数据延时时间为所述时延长度的一半,若比较结果不同则增加时延长度并再次发送特定前导码数据而进行比较,直至比较结果相同为止。
8.如权利要求7所述的SPI长距离通信传输中校正时延的系统,其特征在于,所述解析回环码模块每次增加的时延长度为当前的时延长度和设定的时延长度之和。
9.如权利要求6所述的SPI长距离通信传输中校正时延的系统,其特征在于,所述第二CPLD算法单元包括检析数据模块、与所述检析数据模块连接的判断模块、与所述判断模块连接数据透传模块、以及与所述判断模块连接的回环模块;
所述检析数据模块用于检析接收的数据并发送给所述判断模块;
所述判断模块用于判断所述检析数据模块发送的数据是否为特定前导码数据,若是则发送给所述回环模块,若否则发送给所述透传模块;
所述透传模块用于将接收的数据发送给所述业务SPI接口单元;
所述回环模块用于将接收的所述特定前导码数据回传给所述第一CPLD算法单元。
10.如权利要求6所述的SPI长距离通信传输中校正时延的系统,其特征在于,还包括连接于所述第一CPLD算法单元与所述背板连接单元之间的第一数据缓存器和连接于所述第二CPLD算法单元与所述背板连接单元之间的第二数据缓存器,所述第一数据缓存器和所述第二数据缓存器用于为需经所述背板连接单元传输的数据增强信号的驱动能力。
CN201510705343.2A 2015-10-27 2015-10-27 Spi长距离通信传输中校正时延的方法及系统 Active CN105227376B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201510705343.2A CN105227376B (zh) 2015-10-27 2015-10-27 Spi长距离通信传输中校正时延的方法及系统

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201510705343.2A CN105227376B (zh) 2015-10-27 2015-10-27 Spi长距离通信传输中校正时延的方法及系统

Publications (2)

Publication Number Publication Date
CN105227376A true CN105227376A (zh) 2016-01-06
CN105227376B CN105227376B (zh) 2018-03-30

Family

ID=54996087

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201510705343.2A Active CN105227376B (zh) 2015-10-27 2015-10-27 Spi长距离通信传输中校正时延的方法及系统

Country Status (1)

Country Link
CN (1) CN105227376B (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110912634A (zh) * 2019-10-25 2020-03-24 深圳震有科技股份有限公司 基于spi实现时钟同步的方法、存储介质及终端设备

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1698295A (zh) * 2003-01-30 2005-11-16 三星电子株式会社 用于测量和补偿在由光缆相互连接的主基站和远程基站之间的延迟的装置和方法
CN101102131A (zh) * 2006-07-03 2008-01-09 中兴通讯股份有限公司 远端射频单元的传输延时测量方法
CN101795167A (zh) * 2010-01-27 2010-08-04 中国人民解放军理工大学 高精度时延预补偿光纤授时方法
CN102227099A (zh) * 2011-06-03 2011-10-26 武汉盛华微系统技术股份有限公司 具有时延测量系统的光纤接入授时装置
US20120331326A1 (en) * 2011-06-21 2012-12-27 Via Technologies, Inc. Apparatus and method for advanced synchronous strobe transmission
CN103678218A (zh) * 2013-01-22 2014-03-26 威盛电子股份有限公司 补偿同步数据总线的误差的装置与方法

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1698295A (zh) * 2003-01-30 2005-11-16 三星电子株式会社 用于测量和补偿在由光缆相互连接的主基站和远程基站之间的延迟的装置和方法
CN101102131A (zh) * 2006-07-03 2008-01-09 中兴通讯股份有限公司 远端射频单元的传输延时测量方法
CN101795167A (zh) * 2010-01-27 2010-08-04 中国人民解放军理工大学 高精度时延预补偿光纤授时方法
CN102227099A (zh) * 2011-06-03 2011-10-26 武汉盛华微系统技术股份有限公司 具有时延测量系统的光纤接入授时装置
US20120331326A1 (en) * 2011-06-21 2012-12-27 Via Technologies, Inc. Apparatus and method for advanced synchronous strobe transmission
CN103678218A (zh) * 2013-01-22 2014-03-26 威盛电子股份有限公司 补偿同步数据总线的误差的装置与方法

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110912634A (zh) * 2019-10-25 2020-03-24 深圳震有科技股份有限公司 基于spi实现时钟同步的方法、存储介质及终端设备
CN110912634B (zh) * 2019-10-25 2022-04-29 深圳震有科技股份有限公司 基于spi实现时钟同步的方法、存储介质及终端设备

Also Published As

Publication number Publication date
CN105227376B (zh) 2018-03-30

Similar Documents

Publication Publication Date Title
CN205356347U (zh) 用于光模块的多通道并行测试系统
US8963573B2 (en) Universal test system for testing electrical and optical hosts
CN104184617B (zh) 互联设备预加重配置方法、装置、系统及网络设备
US6614236B1 (en) Cable link integrity detector
CN107104742A (zh) 一种面向并行多通道无线信道测量的校准方法及其系统
WO2016150077A1 (zh) 参数处理方法及装置
US9678919B2 (en) Collision detection in EIA-485 bus systems
CN109766232A (zh) 一种PCIe压力眼图测试校准方法
CN101689939A (zh) 通信系统中反馈质量的评估
CN102664837A (zh) 一种自动检测完成高速数字信号收发方向设置匹配的方法
CN106341181A (zh) 光纤链路测试系统
US9568530B2 (en) Active cable testing
CN105703840A (zh) 一种快速选取高速serdes预加重参数的方法
CN101825667A (zh) 电力通信传输通道故障检测设备、故障检测系统及方法
CN101753583A (zh) 一种使用网络多通道进行数据传输的方法
CN105116287A (zh) 一种高压电缆线路故障在线定位系统及其定位方法
WO2015199266A1 (ko) 광통신 선로 감시 장치 및 방법
CN105227376A (zh) Spi长距离通信传输中校正时延的方法及系统
US20040047408A1 (en) Data link analyzer
CN110514931A (zh) 具有车载以太网功能的设备的电磁兼容测试系统及方法
CN219420769U (zh) 一种不同距离光模块的光传输通道代价测试装置
CN103368786B (zh) 控制器局域网络总线数据的测试方法及装置
CN102724144B (zh) 自适应网关装置及其传输数据的方法
CN103413003B (zh) 一种序列传输、接收装置及方法
CN103067241A (zh) 一种can总线信号传输装置及测试系统

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant
TR01 Transfer of patent right
TR01 Transfer of patent right

Effective date of registration: 20201201

Address after: Room 10242, No. 260, Jiangshu Road, Xixing street, Binjiang District, Hangzhou City, Zhejiang Province

Patentee after: Hangzhou Jiji Intellectual Property Operation Co., Ltd

Address before: 201616 Shanghai city Songjiang District Sixian Road No. 3666

Patentee before: Phicomm (Shanghai) Co.,Ltd.

TR01 Transfer of patent right
TR01 Transfer of patent right

Effective date of registration: 20201221

Address after: 8319 Yanshan Road, Bengbu City, Anhui Province

Patentee after: Bengbu Lichao Information Technology Co.,Ltd.

Address before: Room 10242, No. 260, Jiangshu Road, Xixing street, Binjiang District, Hangzhou City, Zhejiang Province

Patentee before: Hangzhou Jiji Intellectual Property Operation Co., Ltd

TR01 Transfer of patent right
TR01 Transfer of patent right

Effective date of registration: 20210311

Address after: 313000 room 1019, Xintiandi commercial office, Yishan street, Wuxing District, Huzhou, Zhejiang, China

Patentee after: Huzhou YingLie Intellectual Property Operation Co.,Ltd.

Address before: 8319 Yanshan Road, Bengbu City, Anhui Province

Patentee before: Bengbu Lichao Information Technology Co.,Ltd.