广告

什么是CAN通信矩阵?如何阅读CAN通信矩阵?

2021-10-13 汽车电子与软件 阅读:
CAN总线是一种通信形式,有了CAN通信矩阵,开发人员就知道他设计的零部件应该接收什么ID的数据,需要发出什么ID的数据。

什么是CAN通信矩阵a06ednc

CAN通信矩阵(CAN Communication Matrix)通常由整车厂完成定义,车辆网络中的各个节点需要遵循该通讯矩阵才能完成信息的交互和共享。a06ednc

我们知道CAN总线是一种通信形式,ISO 11898协议仅仅规定了数据链路层和物理层,也就是说传什么ID、传什么数据是没有定义的,这留给了大家很多遐想空间。对于乘用车来说,满足UDS和尾气排放协议之后,还剩余了绝大部分的ID段。这些ID段由主机厂自主来进行分配,分配好之后会形成一个.xls格式的表格。有了CAN通信矩阵,开发人员就知道他设计的零部件应该接收什么ID的数据,需要发出什么ID的数据。a06ednc

如何阅读CAN通信矩阵

下面我们详细介绍下怎么阅读一份通信矩阵。a06ednc

a06ednc

信号名称:一般是以发送节点的名字开头,“_”后面是具体指代的内容。如BMS_GeneralStatus。a06ednc

信号长度:该信号的长度,单位是bit,位。a06ednc

精度/偏移量:描述信号值如何转变成信号物理值。比如精度是2,偏移量是5,那么信号的真实物理值 = 信号值 * 2 + 5。a06ednc

物理值范围:经过物理值转换后的最大最小值。a06ednc

a06ednc

其他的一些矩阵中还会有这样的表述。a06ednc

起始字节:起始位所在的字节序号。Byte0-Byte7。a06ednc

起始位:信号LSB(least significant bit)所在的位置。通常这个位置是按照下面这个图来说明的。a06ednc

CAN矩阵的核心图a06ednc

信号类型:Boolean 还是 Unsigned。a06ednc

以上是CAN数据矩阵的基本内容。可以看出来,如何通过起始字节、起始位、数据长度,将数据矩阵中的内容对应到这64个小格子中是理解CAN数据矩阵的关键。a06ednc

如何填格子

我们可以用Vector的CAN db++打开ZLG送的j1939.dbc文件。我们在Signals和Layout面板中看到,对于EEC1这个Message来说,它有8个Signal,填充时是从右向左填充的,比方说EngStarterMode这个信号,初始是第48位,长度是4,它的LSB自然就应该在Byte6的第48个位,之后向左填充,MSB是第51位。大家自行填充一下。a06ednc

j1939.dbca06ednc

j1939.dbc矩阵中的EEC1信号a06ednc

下面说下EngSpeed这个奇葩信号,它跨行了,即跨字节了,这就产生了先后的问题。a06ednc

注意我们填格子的方式分为Intel和Motorola两种。如果你的Signals都没有跨字节的问题,那么Intel和Motorola格式出来的效果是一样的。当然这不可能,你无法确保不跨字节。a06ednc

Intel格式也即小端,MSB存放在高字节单元,反映到矩阵图中就是以起始位为原点,自上而下填充。a06ednc

Intel格式,MSB在LSB下面a06ednc

Motorola格式也即大端,MSB存放在低字节单元,反映到矩阵图中就是以起始位为原点,自下而上填充。a06ednc

Motorola格式,MSB在LSB上面a06ednc

New_Signal_5自下而上填充,Motorolaa06ednc

具体采用哪种格式,听主机厂的,这个无绝对,两种格式都需要理解。但从经验上来看以Motorola格式为主。我们回看下EngSpeed这个信号,起始位是24bit,先填充Byte3,之后向下填充Byte4,MSB在39bit上。因此是Intel格式。a06ednc

EEC1中的EngSpeed是Intel格式,Byte3是低有效,Byte4是高有效a06ednc

名词解释:什么是信号的高位?什么是信号的低位?什么是信号的起始位?a06ednc

信号的高位(most significant bit),即最能表达信号特性的因子。比如转速2000rpm,0x7D0,即011111010000b。最左侧的位,数量级最大,牵一发动全身,即高位。a06ednc

信号的低位(least significant bit),即最不能表达信号特性的因子。刚才转速中,最右侧的0,即低位。就好像老板说给你每个月涨薪5元,你毫不在乎。a06ednc

信号的起始位其实就是信号的最低位。主机厂在定义整车CAN总线通信矩阵时,每一个信号都从其最低位开始填写。a06ednc

报文封装原则

1.同一个报文的所有信号须由同一个节点提供。a06ednc

2.同一个报文所有信号的发送时机尽可能相同。a06ednc

3.小于或等于8位的信号,不应跨越字节边界。a06ednc

不大于8位,不应跨越字节边界a06ednc

4.小于或等于16位的信号,不应跨越字边界。a06ednc

5.信号从每个字节的起始位开始排列。a06ednc

要从每个字节的起始位开始排列a06ednc

6.信号排列应当紧凑。a06ednc

阅读原文,关注作者知乎a06ednc

ENDa06ednc

 a06ednc

文章来源及版权属于汽车电子与软件,EDN电子技术设计仅作转载分享,对文中陈述、观点判断保持中立,不对所包含内容的准确性、可靠性或完整性提供任何明示或暗示的保证。如有疑问,请联系Demi.xia@aspencore.com
汽车电子与软件
汽车电子与软件
  • 微信扫一扫
    一键转发
  • 最前沿的电子设计资讯
    请关注“电子技术设计微信公众号”
广告
广告
热门推荐
广告
广告
EE直播间
在线研讨会
广告
面包芯语
广告
向右滑动:上一篇 向左滑动:下一篇 我知道了