CN111030904A - 一种多级通讯下多路can总线消息实时处理方法 - Google Patents

一种多级通讯下多路can总线消息实时处理方法 Download PDF

Info

Publication number
CN111030904A
CN111030904A CN201911157572.XA CN201911157572A CN111030904A CN 111030904 A CN111030904 A CN 111030904A CN 201911157572 A CN201911157572 A CN 201911157572A CN 111030904 A CN111030904 A CN 111030904A
Authority
CN
China
Prior art keywords
data
bus
value
function
sent
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
CN201911157572.XA
Other languages
English (en)
Other versions
CN111030904B (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.)
Tianjin Jinhang Computing Technology Research Institute
Original Assignee
Tianjin Jinhang Computing Technology Research Institute
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 Tianjin Jinhang Computing Technology Research Institute filed Critical Tianjin Jinhang Computing Technology Research Institute
Priority to CN201911157572.XA priority Critical patent/CN111030904B/zh
Publication of CN111030904A publication Critical patent/CN111030904A/zh
Application granted granted Critical
Publication of CN111030904B publication Critical patent/CN111030904B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/28Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
    • H04L12/40Bus networks
    • H04L12/40006Architecture of a communication node
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/28Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
    • H04L12/40Bus networks
    • H04L12/40169Flexible bus arrangements
    • H04L12/40176Flexible bus arrangements involving redundancy
    • H04L12/40182Flexible bus arrangements involving redundancy by using a plurality of communication lines
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/28Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
    • H04L12/40Bus networks
    • H04L2012/40208Bus networks characterized by the use of a particular bus standard
    • H04L2012/40215Controller Area Network CAN

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Information Transfer Systems (AREA)
  • Small-Scale Networks (AREA)

Abstract

本发明属于通信领域,公开了一种多级通讯下多路CAN总线消息实时处理方法,适用于非实时操作系统的主机板和实时操作系统的CAN模块板之间通信,运行QT程序的主机板和运行VxWorks系统的CAN模块板通过UDP协议连接,主机板发出的CAN端口初始化操作和发送数据操作通过UDP通信在CAN模块板直接进行寄存器读写操作达到实时处理效果,CAN总线数据的接收则通过在CAN模块板中断接收服务函数中触发消息传输,在高优先级的发送任务中通过UDP将数据实时发送到主机板中,供应用层使用。本发明采用的方法实时性好,可靠性高。

Description

一种多级通讯下多路CAN总线消息实时处理方法
技术领域
本发明属于通信技术领域,涉及一种多级通讯下多路CAN总线消息实时处理方法。
背景技术
在通用型的Intel X86主机板中较多配备的接口为网口、串口、USB,CAN总线是一种实时通讯型总线,一般用在实时操作系统中或者裸机中,但是在某些应用中,X86主机板也需要使用CAN总线通讯,而直接在集成度较高的主机板上设计CAN总线电路,往往会破坏原有成熟的主机板产品,虽然通过USB外挂CAN模块板是一个常用选择,但是USB总线特性不适合工业现场使用,因此替代方案可以采用以太网外挂CAN模块板,传统上主机板编程多采用TCPIP,主机板和CAN模块板建立TCP连接,主机发送命令后,CAN板响应命令,这种以太网外挂CAN模块板存在下述两个缺点:(1)TCPIP需要建立连接,中途断连需要重连,TCPIP断网重连严重影响了系统的实时性;(2)主机发送命令后,CAN板响应命令,对于数据接收的延时较长。
发明内容
(一)发明目的
本发明的目的是:提供一种多级通讯下多路CAN总线消息实时处理方法,以解决主机板和CAN模块板间数据的实时处理问题。
(二)技术方案
为了解决上述技术问题,本发明提供一种、一种多级通讯下多路CAN总线消息实时处理方法,其包括以下步骤:
S1:进行CAN总线的初始化工作;
S2:建立主板和CAN模块板间的UDP链接关系;
S3:CAN模块板收到初始化指令,进行协议的解析计算;
S4:CAN模块收到数据发送指令,解析协议计算出数据发送信息,对数据发送的信息进行处理,然后通过直接操作寄存器完成CAN总线数据的发送操作。
S5:通过硬件芯片SJA1000将数据发送出去。
S6:使用CAN数据接收函数,在底层数据缓冲区中取出数据信息,完成CAN数据的传输。
所述步骤S1中,CAN总线的初始化工作包括:在QT中进行CAN总线参数初始化,包括CAN模块的通道号chan、CAN ID值candid、远程帧标志RTL、扩展帧标志msgMode、波特率信息baudrate、CAN节点的掩码MASKCODE和CAN节点的过滤器ACCCODE;CAN数据的发送包括CAN模块的通道号以及要发送的CAN帧数据。
所述步骤S2中,将要发送的CAN数据和初始化命令使用writeDatagram函数发送到CAN模块板,在CAN模块板中高优先级网络任务使用recvfrom网络接收函数等待主板发送指;CAN模块板中接收到的指令和数据在下行任务TASKDOWN中处理,如果将初始化指令发送到CAN模块板,则转到S3;如果发送数据到CAN模块板,则转到S4。
所述步骤S3中,协议解析计算,计算出CAN模块的通道号、CAN ID值、RTL值、msgMode值、baudrate值以及MASKCODE和ACCCODE值,然后直接操作寄存器完成对应端口的CAN总线初始化操作。
所述步骤S4中,解析协议计算出数据发送的CAN ID值、RTL值、msgMode值、准备发送数据的长度Len和准备发送数据的内容,对数据发送的信息进行处理,然后通过直接操作寄存器完成CAN总线数据的发送操作。
所述步骤S5中,硬件芯片SJA1000将数据发送出去的过程为:
S51:SJA1000收到CAN总线发送的CAN数据后,在中断服务函数中接收到数据后,将接收到CAN数据在中断中直接放入缓冲区中,消息队列从中断中发出,发出到CAN数据上行任务TaskUP中;
S52:通过消息队列将接收到标志RecvFlag和通道号chan,以及CAN总线数据,在VxWorks系统中使用recvfrom函数接收中断发送过来的数据,接收到数据后填充UDP协议数据;
S53:使用sendto函数将将网络报文将UDP协议数据发送到主板中;
S54:主板中底层收到UDP数据后产生readready信号,在主板中采用QT中信号与槽的操作,ready信号触发数据接收槽函数DataTackle();此函数将解析出来的CAN数据存放到环形缓冲区中,等待QT调用接收函数将CAN总线数据取出。
所述步骤S6中,使用CAN数据接收函数,在底层数据缓冲区中取出通道号chan、CANID值、远程帧标志RTL、扩展帧标志msgMode、波特率信息baudrate和CAN数据值完成CAN数据的传输。
(三)有益效果
上述技术方案所提供的多级通讯下多路CAN总线消息实时处理方法,CAN数据的接收采用CAN中断服务函数中触发消息队列,在高优先级中任务发送的方法,解决了传统上CAN多级通讯实时性差、易出错的问题,CAN数据的发送采用直接操作寄存器的方式进行CAN总线数据的发送。
附图说明
图1为多级通讯下多路CAN总线消息实时处理方法流程图。
具体实施方式
为使本发明的目的、内容和优点更加清楚,下面结合附图和实施例,对本发明的具体实施方式作进一步详细描述。
为了解决多级通讯下多路CAN总线消息实时处理问题,结合图1说明本发明多级通讯下多路CAN总线消息实时处理方法流程:
S1:进行CAN总线的初始化工作,在QT中进行CAN总线参数初始化,包括CAN模块的通道号chan,CAN ID值candid,远程帧标志RTL,扩展帧标志msgMode,波特率信息baudrate、CAN节点的掩码MASKCODE和CAN节点的过滤器ACCCODE。CAN数据的发送包括CAN模块的通道号以及要发送的CAN帧数据(1~8个字节)。
S2:建立主板和CAN模块板间的UDP链接关系,将要发送的CAN数据和初始化命令使用writeDatagram函数发送到CAN模块板。在CAN模块板中高优先级网络任务使用recvfrom网络接收函数等待主板发送指令。CAN模块板中接收到的指令和数据在下行任务TASKDOWN中处理,如果将初始化指令发送到CAN模块板,则转到STEP3,如果发送数据到CAN模块板则转到STEP4。
S3:CAN模块板收到初始化指令,经过协议的解析计算,计算出CAN模块的通道号、CAN ID值、RTL值、msgMode值、baudrate值以及MASKCODE和ACCCODE值,然后直接操作寄存器完成对应端口的CAN总线初始化操作。
S4:CAN模块收到数据发送指令,解析协议计算出数据发送的CAN ID值、RTL值、msgMode值、准备发送数据的长度Len和准备发送数据的内容,对数据发送的信息进行处理,然后通过直接操作寄存器完成CAN总线数据的发送操作。
S5:通过硬件芯片SJA1000将数据发送出去。
实施主板接收CAN数据的具体实施方式如下:
S51:SJA1000收到CAN总线发送的CAN数据后,在中断服务函数中接收到数据后,将接收到CAN数据在中断中直接放入缓冲区中,消息队列从中断中发出,发出到CAN数据上行任务TaskUP中。
S52:通过消息队列将接收到标志RecvFlag和通道号chan,以及CAN总线数据,在VxWorks系统中使用recvfrom函数接收中断发送过来的数据,接收到数据后填充UDP协议数据。
S53:使用sendto函数将将网络报文将UDP协议数据发送到主板中。
S54:主板中底层收到UDP数据后产生readready信号,在主板中采用QT中信号与槽的操作,ready信号触发数据接收槽函数DataTackle();此函数将解析出来的CAN数据存放到环形缓冲区中,等待QT调用接收函数将CAN总线数据取出。
S6:使用CAN数据接收函数,在底层数据缓冲区中取出通道号chan、CAN ID值、远程帧标志RTL、扩展帧标志msgMode、波特率信息baudrate和CAN数据值(1~8个数据)完成CAN数据的传输。
利用上述技术方案,采用上述操作步骤,本发明可以实现主机板和CAN模块板间的高速通信,该方法已经经过了算法验证,并进行了仿真实验检验。结果表明,该方案可以是实现主机板和CAN模块板间的高速通信,保证CAN总线消息传递的实时性和可靠性。
以上所述仅是本发明的优选实施方式,应当指出,对于本技术领域的普通技术人员来说,在不脱离本发明技术原理的前提下,还可以做出若干改进和变形,这些改进和变形也应视为本发明的保护范围。

Claims (7)

1.一种多级通讯下多路CAN总线消息实时处理方法,其特征在于,包括以下步骤:
S1:进行CAN总线的初始化工作;
S2:建立主板和CAN模块板间的UDP链接关系;
S3:CAN模块板收到初始化指令,进行协议的解析计算;
S4:CAN模块收到数据发送指令,解析协议计算出数据发送信息,对数据发送的信息进行处理,然后通过直接操作寄存器完成CAN总线数据的发送操作。
S5:通过硬件芯片SJA1000将数据发送出去。
S6:使用CAN数据接收函数,在底层数据缓冲区中取出数据信息,完成CAN数据的传输。
2.如权利要求1所述的多级通讯下多路CAN总线消息实时处理方法,其特征在于,所述步骤S1中,CAN总线的初始化工作包括:在QT中进行CAN总线参数初始化,包括CAN模块的通道号chan、CAN ID值candid、远程帧标志RTL、扩展帧标志msgMode、波特率信息baudrate、CAN节点的掩码MASKCODE和CAN节点的过滤器ACCCODE;CAN数据的发送包括CAN模块的通道号以及要发送的CAN帧数据。
3.如权利要求2所述的多级通讯下多路CAN总线消息实时处理方法,其特征在于,所述步骤S2中,将要发送的CAN数据和初始化命令使用writeDatagram函数发送到CAN模块板,在CAN模块板中高优先级网络任务使用recvfrom网络接收函数等待主板发送指;CAN模块板中接收到的指令和数据在下行任务TASKDOWN中处理,如果将初始化指令发送到CAN模块板,则转到S3;如果发送数据到CAN模块板,则转到S4。
4.如权利要求3所述的多级通讯下多路CAN总线消息实时处理方法,其特征在于,所述步骤S3中,协议解析计算,计算出CAN模块的通道号、CAN ID值、RTL值、msgMode值、baudrate值以及MASKCODE和ACCCODE值,然后直接操作寄存器完成对应端口的CAN总线初始化操作。
5.如权利要求4所述的多级通讯下多路CAN总线消息实时处理方法,其特征在于,所述步骤S4中,解析协议计算出数据发送的CAN ID值、RTL值、msgMode值、准备发送数据的长度Len和准备发送数据的内容,对数据发送的信息进行处理,然后通过直接操作寄存器完成CAN总线数据的发送操作。
6.如权利要求5所述的多级通讯下多路CAN总线消息实时处理方法,其特征在于,所述步骤S5中,硬件芯片SJA1000将数据发送出去的过程为:
S51:SJA1000收到CAN总线发送的CAN数据后,在中断服务函数中接收到数据后,将接收到CAN数据在中断中直接放入缓冲区中,消息队列从中断中发出,发出到CAN数据上行任务TaskUP中;
S52:通过消息队列将接收到标志RecvFlag和通道号chan,以及CAN总线数据,在VxWorks系统中使用recvfrom函数接收中断发送过来的数据,接收到数据后填充UDP协议数据;
S53:使用sendto函数将将网络报文将UDP协议数据发送到主板中;
S54:主板中底层收到UDP数据后产生readready信号,在主板中采用QT中信号与槽的操作,ready信号触发数据接收槽函数DataTackle();此函数将解析出来的CAN数据存放到环形缓冲区中,等待QT调用接收函数将CAN总线数据取出。
7.如权利要求6所述的多级通讯下多路CAN总线消息实时处理方法,其特征在于,所述步骤S6中,使用CAN数据接收函数,在底层数据缓冲区中取出通道号chan、CAN ID值、远程帧标志RTL、扩展帧标志msgMode、波特率信息baudrate和CAN数据值完成CAN数据的传输。
CN201911157572.XA 2019-11-22 2019-11-22 一种多级通讯下多路can总线消息实时处理方法 Active CN111030904B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201911157572.XA CN111030904B (zh) 2019-11-22 2019-11-22 一种多级通讯下多路can总线消息实时处理方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201911157572.XA CN111030904B (zh) 2019-11-22 2019-11-22 一种多级通讯下多路can总线消息实时处理方法

Publications (2)

Publication Number Publication Date
CN111030904A true CN111030904A (zh) 2020-04-17
CN111030904B CN111030904B (zh) 2021-12-14

Family

ID=70203150

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201911157572.XA Active CN111030904B (zh) 2019-11-22 2019-11-22 一种多级通讯下多路can总线消息实时处理方法

Country Status (1)

Country Link
CN (1) CN111030904B (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113608782A (zh) * 2021-06-22 2021-11-05 天津津航计算技术研究所 一种能够重定向于can总线的控制台设计方法

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103684944A (zh) * 2012-09-10 2014-03-26 西门子信号有限公司 嵌入式网关、采用该网关的铁路监测系统及其方法
CN104102607A (zh) * 2014-07-17 2014-10-15 航天科工深圳(集团)有限公司 基于VxWorks操作系统环境下的CAN总线驱动方法及系统
CN205545335U (zh) * 2016-04-20 2016-08-31 四川中科智慧智能系统有限公司 一种用于工业现场的数据网关
CN105960629A (zh) * 2013-12-30 2016-09-21 施耐德电气It公司 在can网络中自动选择波特率的系统和方法

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103684944A (zh) * 2012-09-10 2014-03-26 西门子信号有限公司 嵌入式网关、采用该网关的铁路监测系统及其方法
CN105960629A (zh) * 2013-12-30 2016-09-21 施耐德电气It公司 在can网络中自动选择波特率的系统和方法
CN104102607A (zh) * 2014-07-17 2014-10-15 航天科工深圳(集团)有限公司 基于VxWorks操作系统环境下的CAN总线驱动方法及系统
CN205545335U (zh) * 2016-04-20 2016-08-31 四川中科智慧智能系统有限公司 一种用于工业现场的数据网关

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
王庆贺; 吴文杰; 樊兵团; 何威: "UDP转CAN协议的数据传输系统开发", 《科技与创新》 *
黄天戍; 罗璠; 肖文华: "CAN总线到Ethernet网的网关研究实现", 《工业仪表与自动化装置》 *

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113608782A (zh) * 2021-06-22 2021-11-05 天津津航计算技术研究所 一种能够重定向于can总线的控制台设计方法
CN113608782B (zh) * 2021-06-22 2023-08-01 天津津航计算技术研究所 一种能够重定向于can总线的控制台设计方法

Also Published As

Publication number Publication date
CN111030904B (zh) 2021-12-14

Similar Documents

Publication Publication Date Title
US20200174953A1 (en) Methods and apparatus for synchronizing uplink and downlink transactions on an inter-device communication link
US6526446B1 (en) Hardware only transmission control protocol segmentation for a high performance network interface card
CN111656336B (zh) 一种pcie发送、接收方法及装置、设备和系统
EP3681081A1 (en) Data transmission method, device and system
KR101981334B1 (ko) 분산형 데이터 패킷 처리가 적용된 이동통신 시스템 및 방법
CN104102603B (zh) 通用串行总线网络接口控制器及其操作模式切换方法
CN111970353A (zh) 云计算平台物联网中异构设备的数据处理方法及装置
CN101957808B (zh) 多cpu间的通信方法、系统及cpu
CN102710758A (zh) 一种基于单片机系统的数据流断点续传方法
CN107748509B (zh) 基于单片机收发控制的asi通信从机实施方法
CN108304335A (zh) 一种通过dma接收串口不定长报文的方法
CN111030904B (zh) 一种多级通讯下多路can总线消息实时处理方法
CN109062834B (zh) 基于dma的spi通讯方法、电子设备、存储介质、装置
CN109828943A (zh) 一种低速率通信网络的提高串口传输速率处理系统及方法
CN101763324B (zh) 设备模拟的实现方法和装置
CN103368872A (zh) 数据包转发系统和方法
US6567859B1 (en) Device for translating medium access control dependent descriptors for a high performance network
CN112422485A (zh) 一种传输控制协议的通信方法及装置
CN113285839A (zh) 基于dpdk的可编程数据平面软件交换机的设计方法
CN110287141B (zh) 一种基于多种接口的fpga重构方法和系统
CN109814816B (zh) 在can总线上增加打印日志的系统及方法
CN107222379A (zh) 一种串口通信的方法和装置
CN100493018C (zh) 一种通过网络中的总线接口进行通信的方法和系统
CN103347023B (zh) 一种工业现场环境下hdlc通信控制器
CN110913431A (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
GR01 Patent grant
GR01 Patent grant