一文搞懂 CAN 总线协议帧格式
CAN 总线上传输的信息称为报文,当总线空闲时任何连接的单元都可以开始发送新的报文。
CAN 通信是通过以下 5 种类型的帧进行的:
数据帧
遥控帧
错误帧
过载帧
帧间隔
另外,数据帧和遥控帧有标准格式和扩展格式两种格式。标准格式有 11 个位的标识符(Identifier: 以下简称 ID), 扩展格式有 29 个位的 ID。
各种帧的用途如下表所示:
关注公众号:美男子玩编程,优先推送最新技术博文,创作不易,请各位朋友多多点赞、收藏、关注支持~
数据帧由 7 个段构成,图解说明如下所示:
帧起始:表示数据帧开始的段;
仲裁段:表示该帧优先级的段,根据仲裁段 ID 码长度的不同,分为标准帧(CAN 2.0A)和扩展帧(CAN 2.0B);
控制段:表示数据的字节数及保留位的段;
数据段:数据的内容,可发送 0~8 个字节的数据;
CRC 段:检查帧的传输错误的段;
ACK 段:表示确认正常接收的段;
帧结束:表示数据帧结束的段。
1、数据帧
1.1、帧起始
帧起始由 1 个显性位组成。总线空闲时,发送节点发送帧起始,其他接收节点同步于该帧起始位。
总线上的电平有显性电平和隐性电平两种。
总线上执行逻辑上的线“与”时,显性电平的逻辑值为“0”,隐性电平为“1”。
“显性”具有“优先”的意味,只要有一个单元输出显性电平,总线上即为显性电平。并且,“隐性”具有“包容”的意味,只有所有的单元都输出隐性电平,总线上才为隐性电平。(显性电平比隐性电平更强。)
1.2、仲裁段
仲裁段用于写明需要发送到目的 CAN 节点的地址、确定发送的帧类型(当前发送的是数据帧还是遥控帧),并确定发送的帧格式是标准帧还是扩展帧。
仲裁段在标准格式帧和扩展格式帧中有所不同。标准格式帧的仲裁段由 11 位标识符和远程发送请求位 RTR 组成,扩展格式帧的仲裁场由 29 位标识符和远程发送请求位 RTR 组成。
1.2.1、标准数据帧
标准数据帧基于早期的 CAN 规格(1.0 和 2.0A 版),使用了 11 位的识别域。
CAN 标准帧帧信息是 11 字节,包括帧描述符和帧数据两部分。如下表所列:
前 3 字节为帧描述部分。字节 1 为帧信息,第 7 位(FF)表示帧格式,在标准帧中 FF=0,第 6 位(RTR)表示帧的类型,RTR=0 表示为数据帧,RTR=1 表示为远程帧。DLC 表示在数据帧时实际的数据长度。
标准数据帧的 ID 有 11 个位。从 ID10 到 ID0 依次发送。禁止高 7 位都为隐性(禁止设定:ID=1111111XXXX)。
字节 2~3 为报文识别码,其高 11 位有效。
字节 4~11 为数据帧的实际数据,远程帧时无效。
1.2.2、扩展数据帧
CAN 扩展帧帧信息是 13 字节,包括帧描述符和帧数据两部分,如下表所示:
前 5 字节为帧描述部分。字节 1 为帧信息,第 7 位(FF)表示帧格式,在扩展帧中 FF=1,第 6 位(RTR)表示帧的类型,RTR=0 表示为数据帧,RTR=1 表示为远程帧。DLC 表示在数据帧时实际的数据长度。
扩展格式的 ID 有 29 个位。基本 ID 从 ID28 到 ID18,扩展 ID 由 ID17 到 ID0 表示。基本 ID 和 标准格式的 ID 相同。禁止高 7 位都为隐性(禁止设定:基本 ID=1111111XXXX)。
字节 2~5 为报文识别码,其高 28 位有效。
字节 6~13 为数据帧的实际数据,远程帧时无效。
1.3、控制段
控制段由 6 个位组成,包括数据长度代码和两个将来作为扩展用的保留位,标准格式和扩展格式的构成有所不同。
数据长度代码指示了数据段中的字节数量。数据长度代码为 4 个位,在控制段里被发送,数据帧长度允许的字节数为 0、1、2、3、4、5、6、7、8,其他数值为非法的。
保留位(r0、r1)必须全部以显性电平发送。但接收方可以接收显性、隐性及其任意组合的电平。
数据长度码(DLC)与数据的字节数的对应关系如下表所示:
数据的字节数必须为 0~8 字节,但接收方对 DLC = 9~15 的情况并不视为错误。
1.4、数据段
数据段由数据帧中的发送数据组成,它可以为 0~8 字节,每字节包含了 8 位,首先发送最高有效位 MSB,依次发送至最低有效位 LSB。
1.5、CRC 段
CRC 段是检查帧传输错误的帧,包括:15 个位的 CRC 序列(CRC SEQUENCE)和 1 个位的 CRC 界定符(CRC DELIMITER)构成。
CRC 序列是根据多项式生成的 CRC 值,CRC 的计算范围包括:帧起始、仲裁段、控制段、数据 段。 接收方以同样的算法计算 CRC 值并进行比较,不一致时会通报错误。
1.6、ACK 段
ACK 段用来确认是否正常接收。由 ACK 槽(ACK SLOT)和 ACK 界定符(ACK DELIMITER)2 个位构成。
发送单元在 ACK 段发送 2 个位的隐性位。当接收器正确地接收到有效的报文时,接收器就会在应答间隙(ACK SLOT)期间(发送 ACK 信号)向发送器发送一个“显性”的位以示应答,通知发送单元正常接收结束,这称作“发送 ACK”或者“返回 ACK”。
发送 ACK/返回 ACK 是在既不处于总线关闭态也不处于休眠态的所有接收单元中,接收到正常消息的单元 (发送单元不发送 ACK)。所谓正常消息是指不含填充错误、格式错误、CRC 错误的消息。
1.7、帧结束
帧结束是由每一个数据帧和远程帧的标志序列界定的,这个标志序列由 7 个“隐性”位组成。
2、标准数据帧和扩展数据帧
CAN 协议可以接收和发送 11 位标准数据帧和 29 位扩展数据帧,CAN 标准数据帧和扩展数据帧只是帧 ID 长度不同,以便可以扩展更多 CAN 节点。
2.1、标准数据帧
标准数据帧基于早期的 CAN 规格(1.0 和 2.0A 版),使用了 11 位的识别域。
CAN 标准帧帧信息是 11 字节,包括帧描述符和帧数据两部分。如下表所列:
前 3 字节为帧描述部分。字节 1 为帧信息,第 7 位(FF)表示帧格式,在标准帧中 FF=0,第 6 位(RTR)表示帧的类型,RTR=0 表示为数据帧,RTR=1 表示为远程帧。DLC 表示在数据帧时实际的数据长度。
标准数据帧的 ID 有 11 个位。从 ID10 到 ID0 依次发送,可以出现 2^11 种报文,帧 ID 的范围是:000-7FF,禁止高 7 位都为隐性(禁止设定:ID=1111111XXXX)。
字节 2~3 为报文识别码,其高 11 位有效。
字节 4~11 为数据帧的实际数据,远程帧时无效。
2.2、扩展数据帧
CAN 扩展帧帧信息是 13 字节,包括帧描述符和帧数据两部分,如下表所示:
前 5 字节为帧描述部分。字节 1 为帧信息,第 7 位(FF)表示帧格式,在扩展帧中 FF=1,第 6 位(RTR)表示帧的类型,RTR=0 表示为数据帧,RTR=1 表示为远程帧。DLC 表示在数据帧时实际的数据长度。
扩展格式的 ID 有 29 个位,基本 ID 从 ID28 到 ID18,扩展 ID 由 ID17 到 ID0 表示,基本 ID 和 标准格式的 ID 相同,可以出现 2^29 种报文,且在数据链路上是有间隙的(对操作者透明),帧 ID 的范围是 0000 0000-1FFF FFFF,禁止高 7 位都为隐性(禁止设定:基本 ID=1111111XXXX)。
字节 2~5 为报文识别码,其高 28 位有效。
字节 6~13 为数据帧的实际数据,远程帧时无效。
2.3、标准数据帧和扩展数据帧的特性
CAN 标准数据帧和扩展数据帧只是帧 ID 长度不同,功能上都是相同的,它们有一个共同的特性:帧 ID 数值越小,优先级越高。
3、遥控帧
3.1、遥控帧格式
遥控帧是接收单元向发送单元请求发送数据所用的帧,遥控帧由 6 个段组成,遥控帧没有数据段。
遥控帧的构成如下所示:
帧起始(SOF):表示帧开始的段;
仲裁段:表示该帧优先级的段。可请求具有相同 ID 的数据帧;
控制段:表示数据的字节数及保留位的段;
CRC 段:检查帧的传输错误的段;
ACK 段:表示确认正常接收的段;
帧结束:表示遥控帧结束的段。
遥控帧格式如下图所示:
3.2、数据帧和遥控帧的区别
数据帧和遥控帧主要有两点区别:
遥控帧没有数据帧的数据段;
遥控帧 RTR 位是隐性,RTR 位的极性表示了所发送的帧是数据帧(RTR 位“显性”)还是远程帧(RTR 位“隐性”)。所以,没有数据段的数据帧和遥控帧可通过 RTR 位区别开来。
4、错误帧
4.1、错误帧格式
错误帧由错误标志(Error Flag)和错误界定符(Error Delimiter)组成。
接收节点发现总线上的报文有错误时,将自动发出活动错误标志,它是 6 个连续的显性位。其他节点检测到活动错误标志后发送错误认可标志,它由 6 个连续的隐性位组成。由于各个接收节点发现错误的时间可能不同,所以总线上实际的错误标志可能由 6~12 个显性位组成。
错误界定符由 8 个位的隐性位构成。当错误标志发生后,每一个 CAN 节点监视总线,直至检测到一个显性电平的跳变。此时表示所有的节点已经完成了错误标志的发送,并开始发送 8 个隐性电平的界定符。
如下所示:
4.2、主动错误标志和被动错误标志
错误标志包括主动错误标志和被动错误标志两种。
主动错误标志:处于主动错误状态的单元检测出错误时输出的错误标志,6 个位的显性位;
被动错误标志:处于被动错误状态的单元检测出错误时输出的错误标志,6 个位的隐性位。
4.3、错误帧种类
错误帧共有 5 种,多种错误可能同时发生,种类如下所示:
位错误
填充错误
CRC 错误
格式错误
ACK 错误
错误的种类、错误的内容、错误检测帧和检测单元如下表所示:
重点聊一聊位错误和格式错误。
位错误特性如下所示:
位错误由向总线上输出数据帧、遥控帧、错误帧、过载帧的单元和输出 ACK 的单元、输出错误的单元来检测;
在仲裁段输出隐性电平,但检测出显性电平时,将被视为仲裁失利,而不是位错误;
在仲裁段作为填充位输出隐性电平时,但检测出显性电平时,将不视为位错误,而是填充错误;
发送单元在 ACK 段输出隐性电平,但检测到显性电平时,将被判断为其它单元的 ACK 应答,而非位错误;
输出被动错误标志(6 个位隐性位)但检测出显性电平时,将遵从错误标志的结束条件,等待检测出连续相同 6 个位的值(显性或隐性),并不视为位错误。
格式错误特性如下所示:
即使接收单元检测出 EOF(7 个位的隐性位)的最后一位(第 8 个位)为显性电平,也不视为格式错误;
即使接收单元检测出数据长度码(DLC)中 9∼15 的值时,也不视为格式错误。
发送单元发送完错误帧后,将再次发送数据帧或遥控帧,错误标志输出时序如下表所示:
5、过载帧
过载帧是用于接收单元通知其尚未完成接收准备的帧,过载帧由过载标志和过载界定符构成。
过载标志由 6 个位的显性位组成,过载标志的构成与主动错误标志的构成相同。过载标志其形式破坏了间歇场的固定格式,结果使其他所有节点也检测到了一个出错状态,就都各自送出一个超载标志。
过载界定符由 8 个位的隐性位组成,过载界定符的构成与错误界定符的构成相同。过载标志发送完毕后,每个节点都对总线进行监察,直到检测到一个隐性位为止。此时,每个节点均已发送完各自的过载标志,接着所有节点还要同时开始发送 7 个隐性位,配齐长达 8 位的过载界定符。
过载帧的构成如下图所示:
6、帧间隔
帧间隔是用于分隔数据帧和遥控帧的帧。数据帧和遥控帧可通过插入帧间隔将本帧与前面的任何帧(数据帧、遥控帧、错误帧、过载帧)分开,过载帧和错误帧前不能插入帧间隔。
帧间隔的构成如下图所示:
帧间隔由间隔段、总线空闲段和延迟传送段组成,具体说明如下所示:
间隔段:间歇由 3 个隐性位构成。在间歇期间,不允许任何节点发送数据帧或远程帧。唯一可以执行的操作是通报超载状态;
总线空闲段:总线空闲时间长短不限。总线一经确认处于空闲状态,则任何节点都可以访问总线来传送信息。因另一帧正在传送而延期发送的帧是从间歇之后的第一位开始送出的。通过对总线进行检测,出现在总线空闲期间的显性位将被认为是帧起始;
延迟传送段:处于错误认可状态的节点完成其发送动作后,在被允许发送下一帧以前,它要在间歇之后送出 8 个隐性位。如果间歇期间执行了(由另一个节点引起的)发送动作,此节点将会变成正被发送的帧的接收器。
版权声明: 本文为 InfoQ 作者【不脱发的程序猿】的原创文章。
原文链接:【http://xie.infoq.cn/article/773bf4511274868e75f142c19】。文章转载请联系作者。
评论