CN114900393A - 改进式spi通信方法、装置及存储介质 - Google Patents
改进式spi通信方法、装置及存储介质 Download PDFInfo
- Publication number
- CN114900393A CN114900393A CN202210690115.2A CN202210690115A CN114900393A CN 114900393 A CN114900393 A CN 114900393A CN 202210690115 A CN202210690115 A CN 202210690115A CN 114900393 A CN114900393 A CN 114900393A
- Authority
- CN
- China
- Prior art keywords
- spi
- information
- processed
- identity
- slave
- 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.)
- Pending
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L12/00—Data switching networks
- H04L12/28—Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
- H04L12/40—Bus networks
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/32—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Communication Control (AREA)
Abstract
本申请实施例基于路由器、交换机、EPON、GPON、OTN、波分及IPRAN设备等提供一种改进式SPI通信方法、装置及存储介质,该方法通过从SPI设备接收主SPI设备发送的待处理信息,该待处理信息包括目标SPI设备的身份标识,进而,根据目标SPI设备的身份标识和从SPI设备的身份标识,确定是否与主SPI设备通信,如果确定与主SPI设备通信,则执行上述待处理信息,并将执行结果返回主SPI设备,不需要增加片选选通电路对多个从设备进行通信选通,解决通过增加片选选通电路对多个从设备进行选通通信,存在选通误操作、成本增加、主控板面积增大,以及占用资源的问题。
Description
技术领域
本申请涉及通信技术领域,尤其涉及一种改进式SPI通信方法、装置及存储介质。
背景技术
在路由器、交换机、以太网无源光网络(Ethernet Passive Optical Network,EPON)、吉比特无源光网络(Gigabit-Capable PON,GPON)、光传送网(optical transportnetwork,OTN)、波分及无线接入网IP化(IP Radio Access Network,IPRAN)等通信设备中,多采用串行外设接口(Serial Peripheral Interface,SPI)总线进行主从通信,以进行信息传输及功能设定等。在标准四线模式下,当有N个从设备时,主设备就需要N个SPI总线,通过N个片选信号对从设备进行片选选通,占用较多资源。
针对此问题,相关技术中,通过增加片选选通电路,对片选信号进行扩展,并增加片选控制信号对片选选通电路进行控制选择,从而实现一个片选对多个从设备进行选通通信。
但是,片选选通电路易受电源及电路性能等的影响,造成选通误操作,导致通信错误,而且,片选选通电路会增加成本且增大主控板面积,另外,片选选通电路对N个从设备选通,仍需N个片选连接,并未减少资源占用。
发明内容
本申请实施例提供了一种改进式SPI通信方法、装置及存储介质,以解决通过增加片选选通电路对多个从设备进行选通通信,存在选通误操作、成本增加、主控板面积增大,以及占用资源的问题。
第一方面,本申请实施例提供了一种改进式SPI通信方法,应用于从SPI设备,所述方法包括:
接收主SPI设备发送的待处理信息,所述待处理信息包括目标SPI设备的身份标识;
根据所述目标SPI设备的身份标识和所述从SPI设备的身份标识,确定是否与所述主SPI设备通信;
若确定与所述主SPI设备通信,则执行所述待处理信息;
将执行结果返回所述主SPI设备。
在一种可能的实现方式中,所述根据所述目标SPI设备的身份标识和所述从SPI设备的身份标识,确定是否与所述主SPI设备通信,包括:
将所述目标SPI设备的身份标识与所述从SPI设备的身份标识进行比较;
若所述目标SPI设备的身份标识与所述从SPI设备的身份标识比较一致,则确定与所述主SPI设备通信;若所述目标SPI设备的身份标识与所述从SPI设备的身份标识比较不一致,则确定不与所述主SPI设备通信。
在一种可能的实现方式中,所述待处理信息还包括校验码;
在所述执行所述待处理信息之前,还包括:
将所述校验码与预存校验码进行比较;
所述执行所述待处理信息,包括:
若所述校验码与所述预存校验码比较一致,则执行所述待处理信息。
在一种可能的实现方式中,所述待处理信息还包括数据处理标志和数据处理地址;
所述执行所述待处理信息,包括:
判断所述数据处理标志是否为读取数据的标志;
若判断所述数据处理标志为读取数据的标志,则从所述数据处理地址读取数据。
在一种可能的实现方式中,所述待处理信息还包括待处理数据;
所述执行所述待处理信息,包括:
判断所述数据处理标志是否为写入数据的标志;
若判断所述数据处理标志为所述写入数据的标志,则将所述待处理数据写入所述数据处理地址。
在一种可能的实现方式中,所述判断所述数据处理标志是否为读取数据的标志,包括:
将所述数据处理标志与预存读取数据标志进行比较;
若所述数据处理标志与所述预存读取数据标志比较一致,则判断所述数据处理标志为读取数据的标志。
第二方面,本申请实施例提供了另一种改进式SPI通信方法,应用于主SPI设备,所述方法包括:
发送待处理信息至所述主SPI设备对应的各个从SPI设备,所述待处理信息包括目标SPI设备的身份标识,所述待处理信息用于指示每一个从SPI设备根据所述目标SPI设备的身份标识和相应从SPI设备的身份标识,确定是否与所述主SPI设备通信,若确定与所述主SPI设备通信,则执行所述待处理信息,并将执行结果返回所述主SPI设备;
接收所述执行结果。
第三方面,本申请实施例提供了一种改进式SPI通信系统,包括:
主SPI设备,用于发送待处理信息至所述主SPI设备对应的各个从SPI设备,所述待处理信息包括目标SPI设备的身份标识;
每一个从SPI设备,用于接收所述待处理信息,根据所述目标SPI设备的身份标识和相应从SPI设备的身份标识,确定是否与所述主SPI设备通信,若确定与所述主SPI设备通信,则执行所述待处理信息,并将执行结果返回所述主SPI设备;
所述主SPI设备,还用于接收所述执行结果。
第四方面,本申请实施例提供了一种改进式SPI通信装置,应用于从SPI设备,所述装置包括:
信息接收模块,用于接收主SPI设备发送的待处理信息,所述待处理信息包括目标SPI设备的身份标识;
通信确定模块,用于根据所述目标SPI设备的身份标识和所述从SPI设备的身份标识,确定是否与所述主SPI设备通信;
信息执行模块,用于若确定与所述主SPI设备通信,则执行所述待处理信息;
结果返回模块,用于将执行结果返回所述主SPI设备。
在一种可能的实现方式中,所述通信确定模块,具体用于:
将所述目标SPI设备的身份标识与所述从SPI设备的身份标识进行比较;
若所述目标SPI设备的身份标识与所述从SPI设备的身份标识比较一致,则确定与所述主SPI设备通信;若所述目标SPI设备的身份标识与所述从SPI设备的身份标识比较不一致,则确定不与所述主SPI设备通信。
在一种可能的实现方式中,所述待处理信息还包括校验码;
所述信息执行模块,具体用于:
将所述校验码与预存校验码进行比较;
若所述校验码与所述预存校验码比较一致,则执行所述待处理信息。
在一种可能的实现方式中,所述待处理信息还包括数据处理标志和数据处理地址;
所述信息执行模块,具体用于:
判断所述数据处理标志是否为读取数据的标志;
若判断所述数据处理标志为读取数据的标志,则从所述数据处理地址读取数据。
在一种可能的实现方式中,所述待处理信息还包括待处理数据;
所述信息执行模块,具体用于:
判断所述数据处理标志是否为写入数据的标志;
若判断所述数据处理标志为所述写入数据的标志,则将所述待处理数据写入所述数据处理地址。
在一种可能的实现方式中,所述信息执行模块,具体用于:
将所述数据处理标志与预存读取数据标志进行比较;
若所述数据处理标志与所述预存读取数据标志比较一致,则判断所述数据处理标志为读取数据的标志。
第五方面,本申请实施例提供了另一种改进式SPI通信装置,应用于主SPI设备,所述装置包括:
信息发送模块,用于发送待处理信息至所述主SPI设备对应的各个从SPI设备,所述待处理信息包括目标SPI设备的身份标识,所述待处理信息用于指示每一个从SPI设备接收所述待处理信息,根据所述目标SPI设备的身份标识和相应从SPI设备的身份标识,确定是否与所述主SPI设备通信,若确定与所述主SPI设备通信,则执行所述待处理信息,并将执行结果返回所述主SPI设备;
结果接收模块,用于接收所述执行结果。
第六方面,本申请实施例提供一种SPI设备,包括:
处理器;
存储器;以及
计算机程序;
其中,所述计算机程序被存储在所述存储器中,并且被配置为由所述处理器执行,所述计算机程序包括用于执行如第一方面所述的方法的指令。
第七方面,本申请实施例提供另一种SPI设备,包括:
处理器;
存储器;以及
计算机程序;
其中,所述计算机程序被存储在所述存储器中,并且被配置为由所述处理器执行,所述计算机程序包括用于执行如第二方面所述的方法的指令。
第八方面,本申请实施例提供一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序使得服务器执行第一方面所述的方法。
第九方面,本申请实施例提供另一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序使得服务器执行第二方面所述的方法。
第十方面,本申请实施例提供一种计算机程序产品,包括计算机指令,所述计算机指令被处理器执行第一方面所述的方法。
第十一方面,本申请实施例提供另一种计算机程序产品,包括计算机指令,所述计算机指令被处理器执行第二方面所述的方法。
本申请实施例提供的改进式SPI通信方法、装置及存储介质,通过从SPI设备接收主SPI设备发送的待处理信息,该待处理信息包括目标SPI设备的身份标识,进而,根据目标SPI设备的身份标识和从SPI设备的身份标识,确定是否与主SPI设备通信,如果确定与主SPI设备通信,则执行上述待处理信息,并将执行结果返回主SPI设备,不需要增加片选选通电路对多个从设备进行通信选通,解决通过增加片选选通电路对多个从设备进行选通通信,存在选通误操作、成本增加、主控板面积增大,以及占用资源的问题。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本申请的实施例,并与说明书一起用于解释本申请的原理。
图1为本申请实施例提供的通过增加片选选通电路进行设备选通通信的示意图;
图2为本申请实施例提供的改进式SPI通信系统架构示意图;
图3为本申请一个实施例提供的改进式SPI通信方法的流程图;
图4为本申请另一个实施例提供的改进式SPI通信方法的流程图;
图5为本申请再一个实施例提供的改进式SPI通信方法的流程图;
图6为本申请一个实施例提供的改进式SPI通信装置的结构示意图;
图7为本申请另一个实施例提供的改进式SPI通信装置的结构示意图;
图8A为本申请实施例提供的一种SPI设备的基本硬件架构示意图;
图8B为本申请实施例提供的另一种SPI设备的基本硬件架构示意图。
通过上述附图,已示出本申请明确的实施例,后文中将有更详细的描述。这些附图和文字描述并不是为了通过任何方式限制本申请构思的范围,而是通过参考特定实施例为本领域技术人员说明本申请的概念。
具体实施方式
这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本申请相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本申请的一些方面相一致的装置和方法的例子。
相关技术中,在路由器、交换机、EPON、GPON、OTN、波分及IPRAN等通信设备中,多采用SPI总线进行主从通信,以进行信息传输及功能设定等。其中,SPI总线是一种高速全双工的通信总线,它使用三条总线和一条或多条片选线来进行主从设备之间的数据传输。三条总线分别为时钟信号(Clock,CLK)、主设备数据输出/从设备数据输入(Master Output/Slave Input,MOSI)、主设备数据输入/从设备数据输出(Master Input/Slave Output,MISO),片选信号(chip select,CS)用于主设备选中总线上的某个从设备并与其进行通讯。在标准四线模式下,当有N个从设备时,主设备就需要N个SPI总线,通过N个片选信号对从设备进行片选选通,占用较多资源。
针对此问题,相关技术中,如图1所示,通过增加片选选通电路,对片选信号进行扩展,并增加片选控制信号对片选选通电路进行控制选择,如图中所示,片选信号CS通过片选选通电路得到片选信号CS1,CS2……,CSn,n为大于2的整数,从而实现主设备通过一个片选对多个从设备(从设备1,从设备2……,从设备n)进行选通通信。但是,片选选通电路易受电源及电路性能等的影响,造成选通误操作,导致通信错误,而且,片选选通电路会增加成本且增大主控板面积,另外,片选选通电路对N个从设备选通,仍需N个片选连接,并未减少资源占用。
为了解决上述问题,本申请实施例提出一种改进式SPI通信方法,主SPI设备发送待处理信息至对应的各个从SPI设备,该待处理信息包括目标SPI设备的身份标识,进而,每一个从SPI设备根据目标SPI设备的身份标识和相应从SPI设备的身份标识,确定是否与主SPI设备通信,如果确定与主SPI设备通信,则执行上述待处理信息,并将执行结果返回主SPI设备,解决通过增加片选选通电路对多个从设备进行选通通信,存在选通误操作、成本增加、主控板面积增大,以及占用资源的问题。
可选地,本申请实施例提供的改进式SPI通信方法可应用于一个设备与多个设备进行通信的场景,不需要使用多个片选或者增加片选选通电路对多个设备进行通信选通,减少管脚占用,节省资源和设备成本。另外,本申请实施例提供的改进式SPI通信方法的应用场景还有很多,例如通过同一总线连接的处理器和多个存储器通信的场景等等,任何采用本申请改进式SPI通信方法的场景都在本申请的范围内。
示例性的,本申请提供的一种改进式SPI通信方法,可以适用于图1所示的改进式SPI通信系统架构示意图,如图2所示,该系统可以包括主SPI设备以及主SPI设备对应的多个从SPI设备。其中,主SPI设备可以理解为设置有SPI总线的设备,从SPI设备可以理解为设置有SPI总线的从属于主SPI设备的设备。这里,如图2所示,从SPI设备有从SPI设备1,从SPI设备2……,从SPI设备n。
在具体实现过程中,在标准四线模式下,主SPI设备通过CLK线发送CLK信号,通过片选信号CS线发送CS信号,另外可以通过MOSI发送待处理信息至主SPI设备对应的各个从SPI设备,上述待处理信息包括目标SPI设备的身份标识。每一个从SPI设备通过MOSI接收上述待处理信息,根据目标SPI设备的身份标识和相应从SPI设备的身份标识,确定是否与主SPI设备通信,如果确定与主SPI设备通信,则执行上述待处理信息,并通过MISO将执行结果返回主SPI设备,主SPI设备通过MISO接收上述执行结果。其中,不需要增加片选选通电路对多个从设备进行通信选通,解决通过增加片选选通电路对多个从设备进行选通通信,存在选通误操作、成本增加、主控板面积增大,以及占用资源的问题。
应理解,上述系统仅为一种示例性系统,具体实施时,可以根据应用需求设置。
可以理解的是,本申请实施例示意的结构并不构成对改进式SPI通信系统架构的具体限定。在本申请另一些可行的实施方式中,上述架构可以包括比图示更多或更少的部件,或者组合某些部件,或者拆分某些部件,或者不同的部件布置,具体可根据实际应用场景确定,在此不做限制。图1所示的部件可以以硬件,软件,或软件与硬件的组合实现。
另外,本申请实施例描述的系统架构是为了更加清楚的说明本申请实施例的技术方案,并不构成对于本申请实施例提供的技术方案的限定,本领域普通技术人员可知,随着系统架构的演变和新业务场景的出现,本申请实施例提供的技术方案对于类似的技术问题,同样适用。
下面以几个实施例为例对本申请的技术方案进行描述,对于相同或相似的概念或过程可能在某些实施例不再赘述。
图3为本申请实施例提供的一种改进式SPI通信方法的流程示意图,本实施例的执行主体可以为图1中的从SPI设备,具体执行主体可以根据实际应用场景确定,本申请实施例对此不做特别限制。如图3所示,本申请实施例提供的改进式SPI通信方法可以包括如下步骤:
S301:接收主SPI设备发送的待处理信息,该待处理信息包括目标SPI设备的身份标识。
这里,上述目标设备可以根据实际情况确定,如上述目标设备为图2中从SPI设备2。上述目标SPI设备的身份标识可以为目标SPI设备的名称、编号、地址等,具体可以根据实际情况设置,如目标SPI设备的身份标识为目标SPI设备的地址。
S302:根据上述目标SPI设备的身份标识和从SPI设备的身份标识,确定是否与主SPI设备通信。
示例性的,主SPI设备对应的每一个从SPI设备在接收主SPI设备发送的待处理信息后,可以将上述目标SPI设备的身份标识与相应从SPI设备的身份标识进行比较。如果上述目标SPI设备的身份标识与从SPI设备的身份标识比较一致,则确定与主SPI设备通信;如果上述目标SPI设备的身份标识与从SPI设备的身份标识比较不一致,则确定不与主SPI设备通信。
例如以上述从SPI设备为图2中从SPI设备2为例,从SPI设备2在接收主SPI设备发送的待处理信息后,将上述目标SPI设备的身份标识与自身的身份标识进行比较,如果两者比较一致,则确定与主SPI设备通信,继续执行后续流程,如果两者比较不一致,则确定不与主SPI设备通信,停止处理。
在本申请实施例中,从SPI设备根据上述目标SPI设备的身份标识和自身的身份标识,确定是否与主SPI设备通信,不需要增加片选选通电路对多个从设备进行通信选通,减少管脚占用,节省资源和设备成本。
S303:若确定与主SPI设备通信,则执行上述待处理信息。
可选地,上述待处理信息还可以包括校验码。
上述从SPI设备还可以进一步将上述校验码与预存校验码进行比较,如果校验码与上述预存校验码比较一致,则执行上述待处理信息,从而,减少上述待处理信息在传输过程中丢失数据或被篡改等,导致后续处理出错的情况,增加通信可靠性。
其中,在接收主SPI设备发送的待处理信息之前,上述从SPI设备还可以接收主SPI设备发送的检验码,如检验码为a5,然后存储检验码a5。主SPI设备发送的待处理信息包括上述校验码,这样,上述从SPI设备在确定与主SPI设备通信后,进行校验,即将主SPI设备发送的待处理信息包括的校验码与预存的校验码a5进行比较,如果两者比较一致,说明主SPI设备发送的待处理信息在传输过程中没有出错,上述从SPI设备可以基于主SPI设备发送的待处理信息进行后续处理,减少后续处理出错的情况。如果两者比较不一致,说明主SPI设备发送的待处理信息在传输过程中出错,上述从SPI设备可以停止处理,并可以反馈主SPI设备信息出错的提示,以使主SPI设备重新发送待处理信息,上述从SPI设备接收主SPI设备重新发送的待处理信息并进行上述处理,提高后续处理结果的准确率。
在本申请实施例中,上述待处理信息还可以包括数据处理标志和数据处理地址。上述从SPI设备在执行上述待处理信息时,可以判断上述数据处理标志是否为读取数据的标志,如果判断上述数据处理标志为读取数据的标志,则从上述数据处理地址读取数据,并将读取的数据返回主SPI设备,处理过程简单,同时保证处理结果的准确性,满足实际应用需要。
其中,上述从SPI设备在判断上述数据处理标志是否为读取数据的标志时,可以将上述数据处理标志与预存读取数据标志进行比较,如果上述数据处理标志与上述预存读取数据标志比较一致,则判断上述数据处理标志为读取数据的标志。
这里,本实施例通过将上述数据处理标志与预存读取数据标志进行比较,判断上述数据处理标志为读取数据的标志,简单方便,提高执行上述待处理信息的速度,也减少执行出错的情况。
示例性的,上述从SPI设备可以接收主SPI设备发送的读取数据标志,如0,进而,存储上述读取数据标志,在接收主SPI设备发送的待处理信息,并确定与主SPI设备通信后,将上述待处理信息中的数据处理标志与预存的读取数据标志进行比较,如将上述待处理信息中的数据处理标志与0进行比较,如果两者比较一致,则判断上述数据处理标志为读取数据的标志,进一步地,可以从上述数据处理地址读取数据,并将读取的数据返回主SPI设备。
另外,上述待处理信息还可以包括待处理数据。上述从SPI设备在执行上述待处理信息,可以判断上述数据处理标志是否为写入数据的标志,如果判断上述数据处理标志为写入数据的标志,则将上述待处理数据写入上述数据处理地址。其中,上述从SPI设备在判断上述数据处理标志是否为写入数据的标志时,可以将上述数据处理标志与预存写入数据标志进行比较,如果上述数据处理标志与上述预存写入数据标志比较一致,则判断上述数据处理标志为写入数据的标志。
可选地,上述从SPI设备可以接收主SPI设备发送的写入数据标志,如1,进而,存储上述写入数据标志,在接收主SPI设备发送的待处理信息,并确定与主SPI设备通信后,将上述待处理信息中的数据处理标志与预存的写入数据标志进行比较,如将上述待处理信息中的数据处理标志与1进行比较,如果两者比较一致,则判断上述数据处理标志为写入数据的标志,进一步地,可以将上述待处理数据写入上述数据处理地址,并返回写入成功的信息至主SPI设备。
在本申请实施例中,以上述待处理信息包括数据处理标志、目标SPI设备的身份标识、数据处理地址、校验码和待处理数据为例,如下述表1所示,上述待处理信息可以包括5个字节,前两个字节包括数据处理标志、目标SPI设备的身份标识和数据处理地址;第三字节为校验码,用以辅助校验确认,提高后续处理可靠度;后两个字节为待处理数据。
表1
这里,上述从SPI设备在接收主SPI设备发送的上述待处理信息后,可以将上述目标SPI设备的身份标识与从SPI设备的身份标识进行比较,如果目标SPI设备的身份标识与从SPI设备的身份标识比较一致,则确定与主SPI设备通信,进一步地,将上述校验码与预存校验码进行比较,如果上述校验码与预存校验码比较一致,则判断上述数据处理标志是否为写入数据的标志,如果判断上述数据处理标志为写入数据的标志,则将上述待处理数据写入上述数据处理地址。
S304:将执行结果返回主SPI设备。
这里,上述从SPI设备在执行上述待处理信息时,判断上述数据处理标志是否为读取数据的标志,如果判断上述数据处理标志为读取数据的标志,则从上述数据处理地址读取数据,并将读取的数据返回主SPI设备。另外,在执行上述待处理信息时,上述从SPI设备还可以判断上述数据处理标志是否为写入数据的标志,如果判断上述数据处理标志为写入数据的标志,则将上述待处理数据写入上述数据处理地址,并返回写入成功的信息至主SPI设备,以便主SPI设备及时获知信息执行结果。
本申请实施例通过从SPI设备接收主SPI设备发送的待处理信息,该待处理信息包括目标SPI设备的身份标识,进而,根据目标SPI设备的身份标识和从SPI设备的身份标识,确定是否与主SPI设备通信,如果确定与主SPI设备通信,则执行上述待处理信息,并将执行结果返回主SPI设备,不需要增加片选选通电路对多个从设备进行通信选通,解决通过增加片选选通电路对多个从设备进行选通通信,存在选通误操作、成本增加、主控板面积增大,以及占用资源的问题。
另外,上述图3从从SPI设备端说明了改进式SPI通信方法的流程,图4给出了从另一端,即主SPI设备对应的改进式SPI通信方法的流程。这里,主SPI设备对应的改进式SPI通信方法的流程参照从SPI设备对应的改进式SPI通信方法的流程。图4为本申请实施例提供了另一种改进式SPI通信方法的流程示意图,其中相关描述参见图3,此处不再赘述,如图4所示,该方法可以包括:
S401:发送待处理信息至主SPI设备对应的各个从SPI设备,上述待处理信息包括目标SPI设备的身份标识,上述待处理信息用于指示每一个从SPI设备根据上述目标SPI设备的身份标识和相应从SPI设备的身份标识,确定是否与主SPI设备通信,若确定与主SPI设备通信,则执行上述待处理信息,并将执行结果返回主SPI设备。
S402:接收上述执行结果。
这里,上述主SPI设备可以对应多个从SPI设备,如图2所示,主SPI设备对应从SPI设备1,从SPI设备2……,从SPI设备n。主SPI设备可以通过广播的方式,发送上述待处理信息至主SPI设备对应的各个从SPI设备。这样,每一个从SPI设备在接收到上述待处理信息后,可以根据上述目标SPI设备的身份标识和相应从SPI设备的身份标识,确定是否与主SPI设备通信,如果确定与主SPI设备通信,则执行上述待处理信息,并将执行结果返回主SPI设备,以便主SPI设备及时获知信息执行结果。
本申请实施例通过主SPI设备发送待处理信息至对应的各个从SPI设备,该待处理信息包括目标SPI设备的身份标识,使得每一个从SPI设备根据目标SPI设备的身份标识和从SPI设备的身份标识,确定是否与主SPI设备通信,如果确定与主SPI设备通信,则执行上述待处理信息,并将执行结果返回主SPI设备,不需要增加片选选通电路对多个从设备进行通信选通,解决通过增加片选选通电路对多个从设备进行选通通信,存在选通误操作、成本增加、主控板面积增大,以及占用资源的问题。
这里,如图5所示,图5给出再一种改进式SPI通信方法的流程示意图,从上述主SPI设备和从SPI设备交互说明上述设备通信的流程,其中,相关描述参见图3和图4,此处不再赘述。
S501:主SPI设备发送待处理信息至主SPI设备对应的各个从SPI设备,上述待处理信息包括目标SPI设备的身份标识。
其中,主SPI设备可以通过广播的方式,发送上述待处理信息至主SPI设备对应的各个从SPI设备。
S502:每一个从SPI设备接收上述待处理信息,根据上述目标SPI设备的身份标识和相应从SPI设备的身份标识,确定是否与主SPI设备通信,若确定与主SPI设备通信,则执行上述待处理信息。
S503:上述从SPI设备将执行结果返回主SPI设备。
这里,每一个从SPI设备在接收上述待处理信息后,可以将上述目标SPI设备的身份标识与自身的身份标识进行比较,如果上述目标SPI设备的身份标识与自身的身份标识比较一致,则确定与主SPI设备通信;如果上述目标SPI设备的身份标识与自身的身份标识比较不一致,则确定不与主SPI设备通信,不需要使用多个片选或者增加片选选通电路对多个辅助板进行通信选通,减少管脚占用,节省资源和设备成本。
可选地,上述待处理信息还可以包括校验码。每一个从SPI设备在执行上述待处理信息之前,还可以将上述校验码与预存校验码进行比较,如果上述校验码与预存校验码比较一致,则执行上述待处理信息,增加通信的可靠性。
在本申请实施例中,上述待处理信息还可以包括数据处理标志和数据处理地址,每一个从SPI设备在执行上述待处理信息时,可以判断上述数据处理标志是否为读取数据的标志,如果判断上述数据处理标志为读取数据的标志,则从上述数据处理地址读取数据。
另外,上述待处理信息还可以包括待处理数据,每一个从SPI设备在执行上述待处理信息时,还可以判断上述数据处理标志是否为写入数据的标志,如果判断上述数据处理标志为写入数据的标志,则将上述待处理数据写入上述数据处理地址。
S504:主SPI设备接收上述执行结果。
综上所述,本申请实施例相对现有技术来说,通过主SPI设备发送待处理信息至对应的各个从SPI设备,该待处理信息包括目标SPI设备的身份标识,使得每一个从SPI设备根据目标SPI设备的身份标识和从SPI设备的身份标识,确定是否与主SPI设备通信,如果确定与主SPI设备通信,则执行上述待处理信息,并将执行结果返回主SPI设备,不需要增加片选选通电路对多个从设备进行通信选通,解决通过增加片选选通电路对多个从设备进行选通通信,存在选通误操作、成本增加、主控板面积增大,以及占用资源的问题。而且,本申请实施例中上述待处理信息还可以包括校验码,每一个从SPI设备还进一步将上述校验码与预存校验码进行比较,如果校验码与上述预存校验码比较一致,则执行上述待处理信息,从而,减少上述待处理信息在传输过程中丢失数据或被篡改等,导致后续处理出错的情况,增加通信可靠性。
对应于上文实施例的改进式SPI通信方法,图6为本申请实施例提供的改进式SPI通信装置的结构示意图。为了便于说明,仅示出了与本申请实施例相关的部分。图6为本申请实施例提供的一种改进式SPI通信装置的结构示意图,该改进式SPI通信装置60包括:信息接收模块601、通信确定模块602、信息执行模块603以及结果返回模块604。这里的改进式SPI通信装置可以是上述从SPI设备本身,或者是实现从SPI设备的功能的芯片或者集成电路。这里需要说明的是,信息接收模块、通信确定模块、信息执行模块以及结果返回模块的划分只是一种逻辑功能的划分,物理上两者可以是集成的,也可以是独立的。
其中,信息接收模块601,用于接收主SPI设备发送的待处理信息,所述待处理信息包括目标SPI设备的身份标识。
通信确定模块602,用于根据所述目标SPI设备的身份标识和所述从SPI设备的身份标识,确定是否与所述主SPI设备通信。
信息执行模块603,用于若确定与所述主SPI设备通信,则执行所述待处理信息。
结果返回模块604,用于将执行结果返回所述主SPI设备。
在一种可能的实现方式中,所述通信确定模块602,具体用于:
将所述目标SPI设备的身份标识与所述从SPI设备的身份标识进行比较;
若所述目标SPI设备的身份标识与所述从SPI设备的身份标识比较一致,则确定与所述主SPI设备通信;若所述目标SPI设备的身份标识与所述从SPI设备的身份标识比较不一致,则确定不与所述主SPI设备通信。
在一种可能的实现方式中,所述待处理信息还包括校验码;
所述信息执行模块603,具体用于:
将所述校验码与预存校验码进行比较;
若所述校验码与所述预存校验码比较一致,则执行所述待处理信息。
在一种可能的实现方式中,所述待处理信息还包括数据处理标志和数据处理地址;
所述信息执行模块603,具体用于:
判断所述数据处理标志是否为读取数据的标志;
若判断所述数据处理标志为读取数据的标志,则从所述数据处理地址读取数据。
在一种可能的实现方式中,所述待处理信息还包括待处理数据;
所述信息执行模块603,具体用于:
判断所述数据处理标志是否为写入数据的标志;
若判断所述数据处理标志为所述写入数据的标志,则将所述待处理数据写入所述数据处理地址。
在一种可能的实现方式中,所述信息执行模块603,具体用于:
将所述数据处理标志与预存读取数据标志进行比较;
若所述数据处理标志与所述预存读取数据标志比较一致,则判断所述数据处理标志为读取数据的标志。
本申请实施例提供的装置,可用于执行上述图3所示方法实施例的技术方案,其实现原理和技术效果类似,本申请实施例此处不再赘述。
图7为本申请实施例提供的另一种改进式SPI通信装置的结构示意图,该改进式SPI通信装置70包括:信息发送模块701以及结果接收模块702。这里的改进式SPI通信装置可以是上述主SPI设备本身,或者是实现主SPI设备的功能的芯片或者集成电路。这里需要说明的是,信息发送模块以及结果接收模块的划分只是一种逻辑功能的划分,物理上两者可以是集成的,也可以是独立的。
其中,信息发送模块701,用于发送待处理信息至所述主SPI设备对应的各个从SPI设备,所述待处理信息包括目标SPI设备的身份标识,所述待处理信息用于指示每一个从SPI设备接收所述待处理信息,根据所述目标SPI设备的身份标识和相应从SPI设备的身份标识,确定是否与所述主SPI设备通信,若确定与所述主SPI设备通信,则执行所述待处理信息,并将执行结果返回所述主SPI设备。
结果接收模块702,用于接收所述执行结果。
本申请实施例提供的装置,可用于执行上述图4所示方法实施例的技术方案,其实现原理和技术效果类似,本申请实施例此处不再赘述。
可选地,图8A和8B示意性地提供本申请所述SPI设备的一种可能的基本硬件架构示意图。
参见图8A和8B,SPI设备包括至少一个处理器801以及通信接口803。进一步可选的,还可以包括存储器802和总线804。
其中,SPI设备中,处理器801的数量可以是一个或多个,图8A和8B仅示意了其中一个处理器801。可选地,处理器801,可以是中央处理器(central processing unit,CPU)、图形处理器(graphics processing unit,GPU)或者数字信号处理器(digital signalprocessor,DSP)。如果SPI设备具有多个处理器801,多个处理器801的类型可以不同,或者可以相同。可选地,SPI设备的多个处理器801还可以集成为多核处理器。
存储器802存储计算机指令和数据;存储器802可以存储实现本申请提供的上述改进式SPI通信方法所需的计算机指令和数据,例如,存储器802存储用于实现上述改进式SPI通信方法的步骤的指令。存储器802可以是以下存储介质的任一种或任一种组合:非易失性存储器(例如只读存储器(Read-Only Memory,ROM)、固态硬盘(Solid State Disk,SSD)、硬盘(Hard Disk Drive,HDD)、光盘),易失性存储器。
通信接口803可以为所述至少一个处理器提供信息输入/输出。也可以包括以下器件的任一种或任一种组合:网络接口(例如以太网接口)、无线网卡等具有网络接入功能的器件。
可选的,通信接口803还可以用于SPI设备与其它计算设备或者终端进行数据通信。
进一步可选的,图8A和8B用一条粗线表示总线804。总线804可以将处理器801与存储器802和通信接口803连接。这样,通过总线804,处理器801可以访问存储器802,还可以利用通信接口803与其它计算设备或者终端进行数据交互。
在本申请中,SPI设备执行存储器802中的计算机指令,使得SPI设备实现本申请提供的上述改进式SPI通信方法,或者使得SPI设备部署上述的改进式SPI通信装置。
从逻辑功能划分来看,示例性的,如图8A所示,存储器802中可以包括信息接收模块601、通信确定模块602、信息执行模块603以及结果返回模块604。这里的包括仅仅涉及存储器中所存储的指令被执行时可以分别实现信息接收模块、通信确定模块、信息执行模块以及结果返回模块的功能,而不限定是物理上的结构。
示例性的,如图8B所示,存储器802中可以包括信息发送模块701以及结果接收模块702。这里的包括仅仅涉及存储器中所存储的指令被执行时可以分别实现信息发送模块以及结果接收模块的功能,而不限定是物理上的结构。
本申请提供一种计算机可读存储介质,所述计算机程序产品包括计算机指令,所述计算机指令指示计算设备执行本申请提供的上述改进式SPI通信方法。
本申请提供一种计算机程序产品,包括计算机指令,所述计算机指令被处理器执行上述改进式SPI通信方法。
本申请提供一种芯片,包括至少一个处理器和通信接口,所述通信接口为所述至少一个处理器提供信息输入和/或输出。进一步,所述芯片还可以包含至少一个存储器,所述存储器用于存储计算机指令。所述至少一个处理器用于调用并运行该计算机指令,以执行本申请提供的上述改进式SPI通信方法。
在本申请所提供的几个实施例中,应该理解到,所揭露的装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本申请各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用硬件加软件功能单元的形式实现。
Claims (10)
1.一种改进式串行外设接口SPI通信方法,其特征在于,应用于从SPI设备,所述方法包括:
接收主SPI设备发送的待处理信息,所述待处理信息包括目标SPI设备的身份标识;
根据所述目标SPI设备的身份标识和所述从SPI设备的身份标识,确定是否与所述主SPI设备通信;
若确定与所述主SPI设备通信,则执行所述待处理信息;
将执行结果返回所述主SPI设备。
2.根据权利要求1所述的改进式SPI通信方法,其特征在于,所述根据所述目标SPI设备的身份标识和所述从SPI设备的身份标识,确定是否与所述主SPI设备通信,包括:
将所述目标SPI设备的身份标识与所述从SPI设备的身份标识进行比较;
若所述目标SPI设备的身份标识与所述从SPI设备的身份标识比较一致,则确定与所述主SPI设备通信;若所述目标SPI设备的身份标识与所述从SPI设备的身份标识比较不一致,则确定不与所述主SPI设备通信。
3.根据权利要求1或2所述的改进式SPI通信方法,其特征在于,所述待处理信息还包括校验码;
在所述执行所述待处理信息之前,还包括:
将所述校验码与预存校验码进行比较;
所述执行所述待处理信息,包括:
若所述校验码与所述预存校验码比较一致,则执行所述待处理信息。
4.根据权利要求1或2所述的改进式SPI通信方法,其特征在于,所述待处理信息还包括数据处理标志和数据处理地址;
所述执行所述待处理信息,包括:
判断所述数据处理标志是否为读取数据的标志;
若判断所述数据处理标志为读取数据的标志,则从所述数据处理地址读取数据。
5.根据权利要求4所述的改进式SPI通信方法,其特征在于,所述待处理信息还包括待处理数据;
所述执行所述待处理信息,包括:
判断所述数据处理标志是否为写入数据的标志;
若判断所述数据处理标志为写入数据的标志,则将所述待处理数据写入所述数据处理地址。
6.根据权利要求4所述的改进式SPI通信方法,其特征在于,所述判断所述数据处理标志是否为读取数据的标志,包括:
将所述数据处理标志与预存读取数据标志进行比较;
若所述数据处理标志与所述预存读取数据标志比较一致,则判断所述数据处理标志为读取数据的标志。
7.一种改进式SPI通信方法,其特征在于,应用于主SPI设备,所述方法包括:
发送待处理信息至所述主SPI设备对应的各个从SPI设备,所述待处理信息包括目标SPI设备的身份标识,所述待处理信息用于指示每一个从SPI设备根据所述目标SPI设备的身份标识和相应从SPI设备的身份标识,确定是否与所述主SPI设备通信,若确定与所述主SPI设备通信,则执行所述待处理信息,并将执行结果返回所述主SPI设备;
接收所述执行结果。
8.一种改进式SPI通信系统,其特征在于,包括:
主SPI设备,用于发送待处理信息至所述主SPI设备对应的各个从SPI设备,所述待处理信息包括目标SPI设备的身份标识;
每一个从SPI设备,用于接收所述待处理信息,根据所述目标SPI设备的身份标识和相应从SPI设备的身份标识,确定是否与所述主SPI设备通信,若确定与所述主SPI设备通信,则执行所述待处理信息,并将执行结果返回所述主SPI设备;
所述主SPI设备,还用于接收所述执行结果。
9.一种改进式SPI通信装置,其特征在于,应用于从SPI设备,所述装置包括:
信息接收模块,用于接收主SPI设备发送的待处理信息,所述待处理信息包括目标SPI设备的身份标识;
通信确定模块,用于根据所述目标SPI设备的身份标识和所述从SPI设备的身份标识,确定是否与所述主SPI设备通信;
信息执行模块,用于若确定与所述主SPI设备通信,则执行所述待处理信息;
结果返回模块,用于将执行结果返回所述主SPI设备。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质中存储有计算机执行指令,所述计算机执行指令被处理器执行时用于实现如权利要求1至6中任一项所述的方法,和/或,所述计算机执行指令被处理器执行时用于实现如权利要求7所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210690115.2A CN114900393A (zh) | 2022-06-17 | 2022-06-17 | 改进式spi通信方法、装置及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210690115.2A CN114900393A (zh) | 2022-06-17 | 2022-06-17 | 改进式spi通信方法、装置及存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN114900393A true CN114900393A (zh) | 2022-08-12 |
Family
ID=82729220
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210690115.2A Pending CN114900393A (zh) | 2022-06-17 | 2022-06-17 | 改进式spi通信方法、装置及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114900393A (zh) |
Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101499046A (zh) * | 2008-01-30 | 2009-08-05 | 鸿富锦精密工业(深圳)有限公司 | Spi设备通信电路 |
US20120072628A1 (en) * | 2010-09-17 | 2012-03-22 | International Business Machines Corporation | Remote multiplexing devices on a serial peripheral interface bus |
CN105468563A (zh) * | 2015-12-28 | 2016-04-06 | 杭州士兰控股有限公司 | Spi从设备、spi通信系统及spi通信方法 |
CN109240971A (zh) * | 2018-09-26 | 2019-01-18 | 威创集团股份有限公司 | 通信方法、装置及系统 |
CN110855686A (zh) * | 2019-11-18 | 2020-02-28 | 深圳开立生物医疗科技股份有限公司 | 一种spi协议通信方法、系统、设备及计算机存储介质 |
CN111611189A (zh) * | 2020-05-28 | 2020-09-01 | 开元通信技术(厦门)有限公司 | 一种通信方法、装置及计算机存储介质 |
CN112416841A (zh) * | 2020-11-10 | 2021-02-26 | 光华临港工程应用技术研发(上海)有限公司 | 基于i2c总线的多机通信的实现方法及多机通信系统 |
-
2022
- 2022-06-17 CN CN202210690115.2A patent/CN114900393A/zh active Pending
Patent Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101499046A (zh) * | 2008-01-30 | 2009-08-05 | 鸿富锦精密工业(深圳)有限公司 | Spi设备通信电路 |
US20120072628A1 (en) * | 2010-09-17 | 2012-03-22 | International Business Machines Corporation | Remote multiplexing devices on a serial peripheral interface bus |
CN105468563A (zh) * | 2015-12-28 | 2016-04-06 | 杭州士兰控股有限公司 | Spi从设备、spi通信系统及spi通信方法 |
CN109240971A (zh) * | 2018-09-26 | 2019-01-18 | 威创集团股份有限公司 | 通信方法、装置及系统 |
CN110855686A (zh) * | 2019-11-18 | 2020-02-28 | 深圳开立生物医疗科技股份有限公司 | 一种spi协议通信方法、系统、设备及计算机存储介质 |
CN111611189A (zh) * | 2020-05-28 | 2020-09-01 | 开元通信技术(厦门)有限公司 | 一种通信方法、装置及计算机存储介质 |
CN112416841A (zh) * | 2020-11-10 | 2021-02-26 | 光华临港工程应用技术研发(上海)有限公司 | 基于i2c总线的多机通信的实现方法及多机通信系统 |
Non-Patent Citations (2)
Title |
---|
李金凤;施慧彬;杨定定;: "双MicroBlaze软核处理器的SOPC系统设计", 单片机与嵌入式系统应用 * |
高振;罗秋凤;: "SPI接口与CRC算法在双DSP数据通信中的应用", 电子产品世界 * |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN111709032A (zh) | 一种在多种分区上实现pfr功能的方法、系统、设备及介质 | |
CN112463702B (zh) | 一种级联背板的cpld i2c通道地址分配方法及系统 | |
US7945807B2 (en) | Communication system for a plurality of I/O cards by using the GPIO and a method thereof | |
CN117896351A (zh) | 从机地址更新方法及相关装置 | |
CN112231251A (zh) | 板卡槽位识别方法、装置、通信设备及可读存储介质 | |
CN114900393A (zh) | 改进式spi通信方法、装置及存储介质 | |
CN106776186B (zh) | 一种多cpu架构下的cpu运行状态调试方法和系统 | |
CN100541468C (zh) | 系统管理总线从属装置的从属地址扫描装置及其方法 | |
CN111258763B (zh) | 一种服务器系统及服务器系统的控制方法和装置 | |
CN102902647B (zh) | 设置在i2c从机印刷电路板的asic芯片和印刷电路板 | |
CN111159078B (zh) | 一种电子设备 | |
CN111027104A (zh) | 一种防止网卡标识数据丢失的方法、装置及主板 | |
CN107851082B (zh) | 用于在总线处运行的集成电路和用于运行该集成电路的方法 | |
CN113765827B (zh) | 一种交换机固件保护系统 | |
CN114579381B (zh) | 磁盘阵列远程调试方法、系统、终端及存储介质 | |
CN214278929U (zh) | 一种计算机模块及计算机设备 | |
CN217739896U (zh) | 一种智能计算模块电路、计算板卡及计算机 | |
CN114996177B (zh) | 一种访问管理板Flash芯片的系统、方法及服务器 | |
CN114880264A (zh) | Pcie信号配置处理方法、系统、终端及存储介质 | |
CN113760791A (zh) | 一种usb控制系统及存储系统 | |
CN115905083A (zh) | 硬盘点灯装置、方法、系统、计算机设备和存储介质 | |
CN115454748A (zh) | 一种测试板卡,一种节点选择方法及组件 | |
CN115563040A (zh) | 一种固件信息获取方法及服务器 | |
CN115562912A (zh) | 一种数据冗余监视方法 | |
CN116366520A (zh) | 物理层设备的链路状态确定方法、装置、设备及存储介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
CB03 | Change of inventor or designer information |
Inventor after: Lu Qihong Inventor after: Wang Honglian Inventor before: Wu Changhao Inventor before: Lu Qihong Inventor before: Wang Honglian |
|
CB03 | Change of inventor or designer information |