基于单片机实现1553b总线通信的方法及系统

文档序号:190313 发布日期:2021-11-02 浏览:41次 >En<

阅读说明:本技术 基于单片机实现1553b总线通信的方法及系统 (Method and system for realizing 1553B bus communication based on single chip microcomputer ) 是由 黄柳莺 张毅 范晓琳 李奕辉 于 2021-07-29 设计创作,主要内容包括:本发明提供了一种基于单片机实现1553B总线通信的方法及系统,包括单片机对1553B芯片读操作方法,包括先读高8位,设置MSB-LSBn=‘1’,进行“哑读”操作,数据丢弃;等待一段时间;设置MSB-LSBn=‘0’,读低地址,存入共用体RTdata的高字节RTdata.bytedata[1];设置MSB-LSBn=‘1’,读高地址,存入共用体的低字节RTdata.bytedata[0];函数返回值是共用体的字RTdata.worddata。本发明克服单片机8位数据接口,与1553B 16位数据总线接口的矛盾,提高数据处理效率,并具有一定的灵活性。(The invention provides a method and a system for realizing 1553B bus communication based on a single chip microcomputer, which comprises a method for reading a 1553B chip by the single chip microcomputer, wherein the method comprises the steps of firstly reading 8 high bits, setting MSB _ LSBn to be 1 &#39;, carrying out &#39; dummy reading &#39; operation and discarding data; waiting for a period of time; setting MSB _ LSBn as &#39;0&#39;, reading a low address, and storing a high byte RTdata of a shared body RTdata [1 ]; setting MSB _ LSBn as &#39;1&#39;, reading a high address, and storing a low byte RTdata of a shared body; the function return value is a common body word rtdata. The invention overcomes the contradiction between the 8-bit data interface of the singlechip and the 1553B 16-bit data bus interface, improves the data processing efficiency and has certain flexibility.)

基于单片机实现1553B总线通信的方法及系统

技术领域

本发明涉及单片机与外围芯片的通信的技术领域,具体地,涉及基于单片机实现1553B总线通信的方法及系统,尤其涉及一种基于单片机实现1553B总线通信的方法。

背景技术

1553B总线是美国空军电子子系统联网的标准总线,该总线具有极高的可靠性,在航空航天等军事领域具有广泛的应用。1553B总线的消息是由多个16位的字组成,速度快,效率高。但目前很多航天产品用单片机来作为总控CPU,只有8位数据总线,在单片机内部一般按字节处理,因为单片机对数据位的处理不灵活,这些接收的数据不会再转化成16位,这势必造成了数据处理上的局限。对于收到的指令,一般是利用终端结合last command寄存器,这样的处理方式,如果在有中断嵌套并且1553B接口芯片的优先级不高的时候,有可能会有丢失指令的风险。

在公告号为CN102447600B的专利文献中公开了一种本发明异步通信方式,具体地说,涉及一种无时钟同步信号单片机实现HOMEBUS总线通信的方法,提供了一种用不具有同步时钟输出异步通信的单片机,在异步通信时用单片机内部PWM信号模拟出同步时钟信号,实现HomeBus总线通信,从而可以随意的选择单片机实现HomeBus通信,而不必局限于H8系列和富士通系列单片机的无时钟同步信号单片机实现HOMEBUS总线通信的方法,单片机设置为具有PWM输出功能的单片机,单片机的RXD、TXD、PWM端口分别和HOMEBUS的RXD、TXD、SCK端口连接。

针对上述中的相关技术,发明人认为存在数据处理效率低且灵活性低的问题,因此,需要提出一种技术方案以改善上述技术问题。

发明内容

针对现有技术中的缺陷,本发明的目的是提供一种基于单片机实现1553B总线通信的方法及系统。

根据本发明提供的一种基于单片机实现1553B总线通信的方法,包括单片机对1553B芯片读操作方法,所述单片机对1553B芯片读操作方法包括如下步骤:

步骤S1:先读高8位,设置MSB_LSBn=‘1’,进行“哑读”操作,数据丢弃;

步骤S2:等待一段时间;

步骤S3:设置MSB_LSBn=‘0’,读低地址,存入共用体RTdata的高字节RTdata.bytedata[1];

步骤S4:设置MSB_LSBn=‘1’,读高地址,存入共用体的低字节RTdata.bytedata[0];

步骤S5:函数返回值是共用体的字RTdata.worddata。

优选地,所述步骤S5中的函数通过访问外部地址,完成哑读操作,等待一段时间后,分别读取高低字节,存放到共用体RTdata中;获取字节操作从低地址开始,将获取的字节从高到低存放。

优选地,所述单片机实现1553B总线通信的方法还包括获得指令堆栈的数据块指针方法,所述指令堆栈的数据块指针方法包括如下步骤:

步骤1:读取指令堆栈的指针;

步骤2:将指令堆栈的指针与定义的变量比较;

步骤3:判断比较的内容是否一致;

步骤4:若不一致,则读取该消息块中的接收指令字Received Command Word,作为新的指令内容,存放到相应的union变量中;

步骤5:对变量加4;

步骤6:重复步骤1-步骤5,直到变量与指令堆栈的指针一致,所有新的指令都被读到并且保存下来,没有遗漏。

优选地,所述步骤4包括如下步骤:

步骤4.1:根据消息块的指令信息,识别出哪个数据块,是遥控还是遥测,调用不同的程序段;

步骤4.2:根据该数据块占用的长度循环取数,取到的数存入某共用体;

步骤4.3:对共用体中的数据进行包头判断,如果不正确即退出这个模块,执行步骤5;

步骤4.4:如果包头判断正确,对各个数据进行模255的ISO校验,直到所有的数据都校验完毕;校验正确后提取有效的阀门控制指令存入相应的寄存器后退出该模块,执行步骤5;如果发现ISO校验错误,直接退出模块,执行的步骤5。

优选地,所述步骤5中的每个消息块占4个字单元,在取完上一条指令后,要对变量加4。

本发明还提供一种基于单片机实现1553B总线通信的系统,包括单片机对1553B芯片读操作系统,所述单片机对1553B芯片读操作系统包括如下模块:

模块M1:先读高8位,设置MSB_LSBn=‘1’,进行“哑读”操作,数据丢弃;

模块M2:等待一段时间;

模块M3:设置MSB_LSBn=‘0’,读低地址,存入共用体RTdata的高字节RTdata.bytedata[1];

模块M4:设置MSB_LSBn=‘1’,读高地址,存入共用体的低字节RTdata.bytedata[0];

模块M5:函数返回值是共用体的字RTdata.worddata。

优选地,所述模块M5中的函数通过访问外部地址,完成哑读操作,等待一段时间后,分别读取高低字节,存放到共用体RTdata中;获取字节操作从低地址开始,将获取的字节从高到低存放。

优选地,所述单片机实现1553B总线通信的系统还包括获得指令堆栈的数据块指针系统,所述指令堆栈的数据块指针系统包括如下模块:

模块1:读取指令堆栈的指针;

模块2:将指令堆栈的指针与定义的变量比较;

模块3:判断比较的内容是否一致;

模块4:若不一致,则读取该消息块中的接收指令字Received Command Word,作为新的指令内容,存放到相应的union变量中;

模块5:对变量加4;

模块6:重复模块1-模块5,直到变量与指令堆栈的指针一致,所有新的指令都被读到并且保存下来,没有遗漏。

优选地,所述模块4包括如下模块:

模块4.1:根据消息块的指令信息,识别出哪个数据块,是遥控还是遥测,调用不同的程序段;

模块4.2:根据该数据块占用的长度循环取数,取到的数存入某共用体;

模块4.3:对共用体中的数据进行包头判断,如果不正确即退出这个模块,执行模块5;

模块4.4:如果包头判断正确,对各个数据进行模255的ISO校验,直到所有的数据都校验完毕;校验正确后提取有效的阀门控制指令存入相应的寄存器后退出该模块,执行模块5;如果发现ISO校验错误,直接退出模块,执行的模块5。

优选地,所述模块5中的每个消息块占4个字单元,在取完上一条指令后,要对变量加4。

与现有技术相比,本发明具有如下的有益效果:

1、本发明克服单片机8位数据接口,与1553B 16位数据总线接口的矛盾,提高数据处理效率,并具有一定的灵活性;

2、本发明利用1553B芯片接收消息后存放在指令堆栈的特点,利用查询而非中断的方式响应1553B总线,RT每次访问数据块指针而不是访问上一条指令寄存器,保证指令不会丢失;

3、本发明不占用1553B芯片中断的资源,对于遥测或者实时性要求不高的应用有很大的优势,能避免处理器内部中断冲突,合理利用资源。

附图说明

通过阅读参照以下附图对非限制性实施例所作的详细描述,本发明的其它特征、目的和优点将会变得更明显:

图1为本发明单片机对1553B芯片读操作流程图;

图2为本发明查询并读取指令流程图。

具体实施方式

下面结合具体实施例对本发明进行详细说明。以下实施例将有助于本领域的技术人员进一步理解本发明,但不以任何形式限制本发明。应当指出的是,对本领域的普通技术人员来说,在不脱离本发明构思的前提下,还可以做出若干变化和改进。这些都属于本发明的保护范围。

本发明提供一种基于单片机实现1553B总线通信的方法及系统,定义一个一维的两个元素的8位字符型数组,一个16位的整型变量,建立共用体,利用共用体中的变量共享存储空间,完成字节和字的转换,以及字节变量的高低位灵活读取。根据程序需要随时更新共用体中的字节或字,按需存取。另一方面,在1553B总线上消息的读取时,直接访问RT指令堆栈中的数据块指针,若判断到该指针已经指向下一条消息,则读取该消息包中的接收指令字(Received Command Word),该指令字就是新的指令内容,读取的数据存入共用体,通过控制共用体的指针,可以逐条访问消息地址,这样就能做到不漏一条消息。并且存入共用体的数据可以灵活的按字节运算或者按字运算。

利用共用体克服单片机8位数据总线匹配1553B的16位数据总线的限制,提高数据处理效率;定义指针追赶指令堆栈中的数据块指针,读取指令字,不漏一条消息;开辟一个共用体union,定义一个一维的两个元素的字符型数组、一个整型变量和一个指针类型,利用指针,完成字节变量的高低位灵活读取,并且可以根据程序需要随时更新共用体中的字节或字,按需存取。

利用共用体配合小尾端处理器体系结构,先读高8位,设置P0.0(MSB_LSBn)=‘1’,进行“哑读”操作,数据丢弃;设置P0.0(MSB_LSBn)=‘0’,读低地址,存入共用体的高字节;设置P0.0(MSB_LSBn)=‘1’,读高地址,存入共用体的低字节。

对1553B总线进行读操作,定义变量“追赶”指令堆栈中的数据块指针,若判断到数据块指针已经指向下一条消息,则读取该消息包中的接收指令字(Received CommandWord),该指令字就是新的指令内容,存入共用体。如果判断到数据块指针跟上一次一样,则表示没有新的消息。如此,根据堆栈空间的大小,可以缓存64条-512条消息不等,通过控制union的指针,可以逐条访问消息地址,这样就能做到不漏一条消息。

取指操作对同一条数据既可以实现字操作,也可以实现字节算法,而不会多占用内存空间。

在软件实现的时候,开辟一个共用体union,因为共用体中的变量共享存储空间,定义一个含两个元素的字符型数组、一个整型变量和一个指针变量来构建共用体,主要的作用是利用两者共享存储空间的特点,完美实现8位和16位的转化,同时利用指针,完成字节变量的高低位灵活读取。根据程序需要随时更新共用体中的字节或字,按需存取。

对于1553B总线上消息的读取,一般来说,都是通过访问上一条指令(lastcommand),但这样的做法容易丢指令。本发明结合开辟的union,直接访问RT指令堆栈中的数据块指针,若判断到该指针已经指向下一条消息,则读取该消息包中的接收指令字(Received Command Word),该指令字就是新的指令内容。如果判断到数据块指针跟上一次一样,则表示没有新的消息。如此,根据堆栈空间的大小,可以缓存64条-512条消息不等,通过控制union中的指针,可以逐条访问消息地址,这样就能做到不漏一条消息。

该发明目前已成功应用于某大型项目上,经过前期个阶段数次测试以及飞行试验验证,未发现丢指令现象。

首先定义一个共用体,内部定义3个成员,一个是内含2个字符型元素的一维数组bytedata[2],一个是整型变量worddata,一个是指针pt。

由于单片机的8位接口模式,8位数据总线同时连接到1553B芯片D15-D8以及D7-D0上,所以需要外部地址线以及选通信号来选择操作的是低字节还是高字节,对于读取的第一个字节要丢弃,称为“哑读”。本方法旨在把读取的字节写入共用体,这样就能把CPU总线的8位数据在内部自动转成16位的字。根据这个思路,设计读1553B总线的函数。

参照图1,具体步骤如下:

步骤S1:先读高8位,设置P0.0(MSB_LSBn)=‘1’,进行“哑读”操作,数据丢弃;步骤S2:等待一段时间;步骤S3:设置P0.0(MSB_LSBn)=‘0’,读低地址,存入共用体RTdata的高字节RTdata.bytedata[1];步骤S4:设置P0.0(MSB_LSBn)=‘1’,读高地址,存入共用体的低字节RTdata.bytedata[0];步骤S5:函数返回值是共用体的字RTdata.worddata。

该函数通过访问外部地址,完成了哑读操作,等待一段时间后,分别读取了高低字节,存放到共用体RTdata中,实现了1553B总线上16位数据的读取。此处需注意,获取字节操作从低地址开始,将获取的字节从高到低存放,这样得到的字才是正常变量的值。

参照图2,通过以下流程获得指令堆栈的数据块指针,步骤如下:

步骤1:读取指令堆栈的指针;步骤2:将指令堆栈的指针与自己定义的变量(假设变量名为Ptstu_my)比较;步骤3:判断比较的内容是否一致;步骤4:若不一致,则读取该消息块中的接收指令字(Received Command Word),作为新的指令内容,存放到相应的union变量(假设变量名为RTarray.worddata)中。

一般新的指令需要验证指令内容是否合法,比如模255的ISO校验,根据下述步骤验证:

步骤4.1:根据消息块的指令信息,识别出哪个数据块,是遥控还是遥测,调用不同的程序段;步骤4.2:根据该数据块占用的长度循环取数,取到的数存入某共用体;步骤4.3:对共用体中的数据进行包头判断,此时用字操作方便,如果不正确的话退出这个模块,执行步骤5;步骤4.4:如果包头判断正确,对各个数据(按字节)进行模255的ISO校验,直到所有的数据都校验完毕。校验正确的话提取有效的阀门控制指令存入相应的寄存器后退出该模块,执行步骤5。如果发现ISO校验错误,直接退出模块,执行的步骤5。

步骤5:对变量Ptstu_my加4。因为每个消息块占4个字单元,所以在取完上一条指令后,为了能追上数据块指针的位置,要对变量Ptstu_my加4;步骤6:重复步骤1-步骤5,直到Ptstu_my与指令堆栈的指针一致。也就是所有新的指令都被读到并且保存了下来,没有遗漏。

本发明还提供一种基于单片机实现1553B总线通信的系统,包括单片机对1553B芯片读操作系统,所述单片机对1553B芯片读操作系统包括如下模块:

模块M1:先读高8位,设置P0.0(MSB_LSBn)=‘1’,进行“哑读”操作,数据丢弃;模块M2:等待一段时间;模块M3:设置P0.0(MSB_LSBn)=‘0’,读低地址,存入共用体RTdata的高字节RTdata.bytedata[1];模块M4:设置P0.0(MSB_LSBn)=‘1’,读高地址,存入共用体的低字节RTdata.bytedata[0];模块M5:函数返回值是共用体的字RTdata.worddata。函数通过访问外部地址,完成哑读操作,等待一段时间后,分别读取高低字节,存放到共用体RTdata中;获取字节操作从低地址开始,将获取的字节从高到低存放。

单片机实现1553B总线通信的系统还包括获得指令堆栈的数据块指针系统,指令堆栈的数据块指针系统包括如下模块:模块1:读取指令堆栈的指针;模块2:将指令堆栈的指针与定义的变量比较;模块3:判断比较的内容是否一致。

模块4:若不一致,则读取该消息块中的接收指令字Received Command Word,作为新的指令内容,存放到相应的union变量中;模块4.1:根据消息块的指令信息,识别出哪个数据块,是遥控还是遥测,调用不同的程序段;模块4.2:根据该数据块占用的长度循环取数,取到的数存入某共用体;模块4.3:对共用体中的数据进行包头判断,如果不正确即退出这个模块,执行模块5;模块4.4:如果包头判断正确,对各个数据进行模255的ISO校验,直到所有的数据都校验完毕;校验正确后提取有效的阀门控制指令存入相应的寄存器后退出该模块,执行模块5;如果发现ISO校验错误,直接退出模块,执行的模块5。

模块5:对变量加4;每个消息块占4个字单元,在取完上一条指令后,要对变量Ptstu_my加4。

模块6:重复模块1-模块5,直到变量与指令堆栈的指针一致,所有新的指令都被读到并且保存下来,没有遗漏。

本发明建立共用体做8位、16位数据转换,也可以通过指针随意读取8位的高字节或低字节,轻松实现字节数据不同的拼凑需求,并节约内存空间,一定程度上解决了单片机8位总线匹配16位外部接口的局限。从应用案例来看,对于同一条指令,有些数据采用字处理比较方便,有些数据需要字节运算。比如数据包的包识别、包长度等,协议里明确定义数据内容的,可以采用读取共用体中的字来判断内容是否正确。但对于数据包的校验,例如用ISO校验方法作为包差错控制,需要对数据进行字节的模255运算,这时就可以通过读取共用体的相应字节来参与运算。

本发明采用追踪数据块指针的方法,可以根据需要开辟堆栈区大小,控制缓存的消息条目,可以缓存64条-512条消息不等,就算CPU由于其它中断打扰未能及时响应1553B总线指令,也能在响应完外部中断后,继续从堆栈读取指令,直到所有新指令都取完,做到无遗漏的接收到指令。

本发明灵活、简单易行,适用于大部分单片机与1553B总线的通信。本方法在探月三期推进线路盒以及新飞船推进系统控制驱动器上都有成功的应用。

本领域技术人员知道,除了以纯计算机可读程序代码方式实现本发明提供的系统及其各个装置、模块、单元以外,完全可以通过将方法步骤进行逻辑编程来使得本发明提供的系统及其各个装置、模块、单元以逻辑门、开关、专用集成电路、可编程逻辑控制器以及嵌入式微控制器等的形式来实现相同功能。所以,本发明提供的系统及其各项装置、模块、单元可以被认为是一种硬件部件,而对其内包括的用于实现各种功能的装置、模块、单元也可以视为硬件部件内的结构;也可以将用于实现各种功能的装置、模块、单元视为既可以是实现方法的软件模块又可以是硬件部件内的结构。

以上对本发明的具体实施例进行了描述。需要理解的是,本发明并不局限于上述特定实施方式,本领域技术人员可以在权利要求的范围内做出各种变化或修改,这并不影响本发明的实质内容。在不冲突的情况下,本申请的实施例和实施例中的特征可以任意相互组合。

11页详细技术资料下载
上一篇:一种医用注射器针头装配设备
下一篇:一种基于大数据的数据分类存储系统及方法

网友询问留言

已有0条留言

还没有人留言评论。精彩留言会获得点赞!

精彩留言,会给你点赞!