CAN基础知识

CAN 简介

CAN 是 Controller Area Network 的缩写(以下称为 CAN),是 ISO 国际标准化的串行通信 协议。在当前的汽车产业中,出于对安全性、舒适性、方便性、低公害、低成本的要求,各种 各样的电子控制系统被开发了出来。由于这些系统之间通信所用的数据类型及对可靠性的要求 不尽相同,由多条总线构成的情况很多,线束的数量也随之增加。为适应“减少线束的数量”、 “通过多个 LAN,进行大量数据的高速通信”的需要,1986 年德国电气商博世公司开发出面向 汽车的 CAN 通信协议。此后,CAN 通过 ISO11898 及 ISO11519 进行了标准化,现在在欧洲已 是汽车网络的标准协议。

现在,CAN 的高性能和可靠性已被认同,并被广泛地应用于工业自动化、船舶、医疗设备、 工业设备等方面。现场总线是当今自动化领域技术发展的热点之一,被誉为自动化领域的计算 机局域网。它的出现为分布式控制系统实现各节点之间实时、可靠的数据通信提供了强有力的 技术支持。

CAN 协议具有一下特点:

1) 多主控制。在总线空闲时,所有单元都可以发送消息(多主控制),而两个以上的单 元同时开始发送消息时,根据标识符(Identifier以下称为ID)决定优先级。ID并不是表示 发送的目的地址,而是表示访问总线的消息的优先级。两个以上的单元同时开始发送消息 时,对各消息ID的每个位进行逐个仲裁比较。仲裁获胜(被判定为优先级最高)的单元 可继续发送消息,仲裁失利的单元则立刻停止发送而进行接收工作。

2) 系统的柔软性。与总线相连的单元没有类似于“地址”的信息。因此在总线上增加单元 时,连接在总线上的其它单元的软硬件及应用层都不需要改变。

3) 通信速度较快,通信距离远。最高1Mbps(距离小于40M),最远可达10KM(速率低 于5Kbps)。

4) 具有错误检测、错误通知和错误恢复功能。所有单元都可以检测错误(错误检测功 能),检测出错误的单元会立即同时通知其他所有单元(错误通知功能),正在发送消息的 单元一旦检测出错误,会强制结束当前的发送。强制结束发送的单元会不断反复地重新发 送此消息直到成功发送为止(错误恢复功能)。

5) 故障封闭功能。CAN可以判断出错误的类型是总线上暂时的数据错误(如外部噪声 等)还是持续的数据错误(如单元内部故障、驱动器故障、断线等)。由此功能,当总线 上发生持续数据错误时,可将引起此故障的单元从总线上隔离出去。

6) 连接节点多。CAN总线是可同时连接多个单元的总线。可连接的单元总数理论上是 没有限制的。但实际上可连接的单元数受总线上的时间延迟及电气负载的限制。降低通信 速度,可连接的单元数增加;提高通信速度,则可连接的单元数减少。

正是因为 CAN 协议的这些特点,使得 CAN 特别适合工业过程监控设备的互连,因此,越 来越受到工业界的重视,并已公认为最有前途的现场总线之一。

CAN 协议经过 ISO 标准化后有两个标准:ISO11898 标准(高速 CAN)和 ISO11519-2 标准 (低速CAN)。其中 ISO11898 是针对通信速率为125Kbps~1Mbps 的高速通信标准,而 ISO11519- 2 是针对通信速率为 125Kbps 以下的低速通信标准。

CAN物理层

本章,我们使用的是 ISO11898 标准,也就是高速 CAN,其拓扑图如图 37.1.1.1 所示。从上图可知,高速 CAN 总线呈现的是一个闭环结构,总线是由两根线 CAN_High 和 CAN_Low 组成,且在总线两端各串联了 120Ω的电阻(用于阻抗匹配,减少回波反射),同时 总线上可以挂载多个节点。每个节点都有 CAN 收发器以及 CAN 控制器,CAN 控制器通常是 MCU 的外设,集成在芯片内部;CAN 收发器则是需要外加芯片转换电路。

CAN 类似 RS485 也是通过差分信号传输数据。根据 CAN 总线上两根线的电位差来判断总 线电平。总线电平分为显性电平和隐性电平,二者必居其一。这是属于物理层特征,ISO11898 物理层特性如图 37.1.1.2 所示:从该特性可以看出,显性电平对应逻辑 0,CAN_H 和 CAN_L 之差为 2V 左右。而隐性电 平对应逻辑 1,CAN_H 和 CAN_L 之差为 0V。在总线上显性电平具有优先权,只要有一个单元 输出显性电平,总线上即为显性电平。而隐形电平则具有包容的意味,只有所有的单元都输出 隐性电平,总线上才为隐性电平(显性电平比隐性电平更强)

CAN 协议层

CAN 协议是通过以下 5 种类型的帧进行的:

另外,数据帧和遥控帧有标准格式和扩展格式两种格式。标准格式有 11 个位的标识符(ID), 扩展格式有 29 个位的 ID。各种帧的用途如表 37.1.2.1 所示:由于篇幅所限,我们这里仅对数据帧进行详细介绍,数据帧一般由 7 个段构成,即:

帧起始。表示数据帧开始的段

仲裁段表示该帧优先级的段。

控制段。表示数据的字节数及保留位的段。

数据段。数据的内容,一帧可发送 0~8 个字节的数据。

CRC 段。检查帧的传输错误的段。

ACK 段。表示确认正常接收的段。

帧结束。表示数据帧结束的段。

数据帧的构成如图 37.1.2.1 所示:图中 D 表示显性电平,R 表示隐形电平(下同)。

帧起始,这个比较简单,标准帧和扩展帧都是由 1 个位的显性电平表示帧起始。

仲裁段,表示数据优先级的段,标准帧和扩展帧格式在本段有所区别,如图 37.1.2.2 所示:标准格式的 ID 有 11 个位。禁止高 7 位都为隐性(禁止设定:ID=1111111XXXX)。扩展格 式的 ID 有 29 个位。基本 ID 从 ID28 到 ID18,扩展 ID 由 ID17 到 ID0 表示。基本 ID 和标准格 式的 ID 相同。禁止高 7 位都为隐性(禁止设定:基本 ID=1111111XXXX)。

其中 RTR 位用于标识是否是远程帧(0,数据帧;1,远程帧),IDE 位为标识符选择位(0, 使用标准标识符;1,使用扩展标识符),SRR 位为代替远程请求位,为隐性位,它代替了标准 帧中的 RTR 位。

控制段,由 6 个位构成,表示数据段的字节数。标准帧和扩展帧的控制段稍有不同,如图 37.1.2.3 所示:上图中,r0 和 r1 为保留位,必须全部以显性电平发送,但是接收端可以接收显性、隐性及 任意组合的电平。DLC 段为数据长度表示段,高位在前,DLC 段有效值为 0~8,但是接收方接 收到 9~15 的时候并不认为是错误。

数据段,该段可包含 0~8 个字节的数据。从最高位(MSB)开始输出,标准帧和扩展帧在 这个段的定义都是一样的。如图 37.1.2.4 所示:

 CRC 段,该段用于检查帧传输错误。由 15 个位的 CRC 顺序和 1 个位的 CRC 界定符(用 于分隔的位)组成,标准帧和扩展帧在这个段的格式也是相同的。如图 37.1.2.5 所示:此段 CRC 的值计算范围包括:帧起始、仲裁段、控制段、数据段。接收方以同样的算法计 算 CRC 值并进行比较,不一致时会通报错误。

ACK 段,此段用来确认是否正常接收。由 ACK 槽(ACK Slot)和 ACK 界定符 2 个位组成。 标准帧和扩展帧在这个段的格式也是相同的。如图 37.1.2.6 所示:发送单元的 ACK,发送 2 个位的隐性位,而接收到正确消息的单元在 ACK 槽(ACK Slot) 发送显性位,通知发送单元正常接收结束,这个过程叫发送 ACK/返回 ACK。发送 ACK 的是在 既不处于总线关闭态也不处于休眠态的所有接收单元中,接收到正常消息的单元(发送单元不 发送 ACK)。所谓正常消息是指不含填充错误、格式错误、CRC 错误的消息。

帧结束,这个段也比较简单,标准帧和扩展帧在这个段格式一样,由 7 个位的隐性位组成。

CAN 位时序

由发送单元在非同步的情况下发送的每秒钟的位数称为位速率。一个位可分为 4 段。

⚫ 同步段(SS)

⚫ 传播时间段(PTS)

⚫ 相位缓冲段 1(PBS1)

⚫ 相位缓冲段 2(PBS2)

这些段又由可称为 Time Quantum(以下称为 Tq)的最小时间单位构成。

1 位分为 4 个段,每个段又由若干个 Tq 构成,这称为位时序。

1 位由多少个 Tq 构成、每个段又由多少个 Tq 构成等,可以任意设定位时序。通过设定位 时序,多个单元可同时采样,也可任意设定采样点。各段的作用和 Tq 数如表 37.1.2.2 所示:1 个位的构成如图 37.1.2.7 所示:上图的采样点,是指读取总线电平,并将读到的电平作为位值的点。位置在 PBS1 结束处。 根据这个位时序,我们就可以计算 CAN 通信的波特率了。

CAN 协议仲裁功能

在总线空闲态,最先开始发送消息的单元获得发送权。当多个单元同时开始发送时,各发 送单元从仲裁段的第一位开始进行仲裁。连续输出显性电平最多的单元可继续发送。实现过程, 如图 37.1.2.8 所示:上图中,单元 1 和单元 2 同时开始向总线发送数据,开始部分他们的数据格式是一样的, 故无法区分优先级,直到 T 时刻,单元 1 输出隐性电平,而单元 2 输出显性电平,此时单元 1 仲裁失利,立刻转入接收状态工作,不再与单元 2 竞争,而单元 2 则顺利获得总线使用权,继 续发送自己的数据。这就实现了仲裁,让连续发送显性电平多的单元获得总线使用权。

CAN 控制器

STM32F1 自带的是 bxCAN,即基本扩展 CAN。它支持 CAN 协议 2.0A 和 2.0B。CAN2.0A 只能处理标准数据帧,扩展帧的内容会识别错误;CAN2.0BActive 可以处理标准数据帧和扩展 数据帧;而 CAN2.0B passive 只能处理标准数据帧,扩展帧的内容会忽略。它的设计目标是,以 最小的 CPU 负荷来高效处理大量收到的报文。它也支持报文发送的优先级要求(优先级特性可 软件配置)。对于安全紧要的应用,bxCAN 提供所有支持时间触发通信模式所需的硬件功能。

STM32F1 的 bxCAN 的主要特点有:

⚫ 支持 CAN 协议 2.0A 和 2.0B 主动模式

⚫ 波特率最高达 1Mbps

⚫ 支持时间触发通信

⚫ 具有 3 个发送邮箱

⚫ 具有 3 级深度的 2 个接收 FIFO

⚫ 可变的过滤器组(最多 28 个)

在 STM32 互联型产品中,带有 2 个 CAN 控制器,而我们使用的 STM32F103ZET6 属于增 强型,不是互联型,只有 1 个 CAN 控制器。双 CAN 的框图如图 37.1.2.9 所示:从图中可以看出两个 CAN 都分别拥有自己的发送邮箱和接收 FIFO,但是他们共用 28 个 过滤器。通过 CAN_FMR 寄存器的设置,可以设置过滤器的分配方式。

STM32 的标识符过滤比较复杂,它的存在减少了 CPU 处理 CAN 通信的开销。STM32 的 过滤器组最多有 28 个(互联型),但是 STM32F103ZET6 只有 14 个(增强型),每个过滤器组 x 由 2 个 32 为寄存器,CAN_FxR1 和 CAN_FxR2 组成。

STM32F1 每个过滤器组的位宽都可以独立配置,以满足应用程序的不同需求。根据位宽的 不同,每个过滤器组可提供:

⚫ 1 个 32 位过滤器,包括:STDID[10:0]、EXTID[17:0]、IDE 和 RTR 位

⚫ 2 个 16 位过滤器,包括:STDID[10:0]、IDE、RTR 和 EXTID[17:15]位

此外过滤器可配置为:屏蔽位模式和标识符列表模式。

在屏蔽位模式下,标识符寄存器和屏蔽寄存器一起,指定报文标识符的任何一位,应该按 照“必须匹配”或“不用关心”处理。

而在标识符列表模式下,屏蔽寄存器也被当作标识符寄存器用。因此,不是采用一个标识 符加一个屏蔽位的方式,而是使用 2 个标识符寄存器。接收报文标识符的每一位都必须跟过滤 器标识符相同。

通过 CAN_FMR 寄存器,可以配置过滤器组的位宽和工作模式,如图 37.1.2.10 所示:为了过滤出一组标识符,应该设置过滤器组工作在屏蔽位模式。

为了过滤出一个标识符,应该设置过滤器组工作在标识符列表模式。应用程序不用的过滤 器组,应该保持在禁用状态。

过滤器组中的每个过滤器,都被编号为(叫做过滤器号,图 37.1.2.9 中的 n)从 0 开始,到某 个最大数值-取决于过滤器组的模式和位宽的设置。

举个简单的例子,我们设置过滤器组 0 工作在:1 个 32 为位过滤器-标识符屏蔽模式,然后 设置 CAN_F0R1=0XFFFF0000,CAN_F0R2=0XFF00FF00。其中存放到 CAN_F0R1 的值就是期 望收到的 ID,即我们希望收到的映像(STID+EXTID+IDE+RTR)最好是:0XFFFF0000。而 0XFF00FF00 就是设置我们需要必须关心的 ID,表示收到的映像,其位[31:24]和位[15:8]这 16 个位的必须和 CAN_F0R1 中对应的位一模一样,而另外的 16 个位则不关心,可以一样,也可 以不一样,都认为是正确的 ID,即收到的映像必须是 0XFFxx00xx,才算是正确的(x 表示不关 心),这里需要注意的是标识符选择位 IDE 和帧类型 RTR 需要一致。其情况如下图 37.1.2.11 所 示:接下来,我们看看 STM32 的 CAN 发送和接收的流程。

CAN 发送流程

CAN 发送流程为:程序选择 1 个空置的邮箱(TME=1)→设置标识符(ID),数据长度和 发送数据→设置 CAN_TIxR 的 TXRQ 位为 1,请求发送→邮箱挂号(等待成为最高优先级)→ 预定发送(等待总线空闲)→发送→邮箱空置。整个流程如图 37.1.2.12 所示:上图中,还包含了很多其他处理,发送中止请求(ABRQ=1)和发送失败处理等。通过这个 流程图,我们大致了解了 CAN 的发送流程,后面的数据发送,我们基本就是按照此流程来走。

CAN 接收流程

CAN 接收到的有效报文,被存储在 3 级邮箱深度的 FIFO 中。FIFO 完全由硬件来管理,从 而节省了 CPU 的处理负荷,简化了软件并保证了数据的一致性。应用程序只能通过读取 FIFO 输出邮箱,来读取 FIFO 中最先收到的报文。这里的有效报文是指那些正确被接收的(直到 EOF 都没有错误)且通过了标识符过滤的报文。前面我们知道 CAN 的接收有 2 个 FIFO,我们每个 过滤器组都可以设置其关联的 FIFO,通过 CAN_FFA1R 的设置,可以将过滤器组关联到 FIFO0/FIFO1。

CAN 接收流程为:FIFO 空→收到有效报文→挂号_1(存入 FIFO 的一个邮箱,这个由硬件 控制,我们不需要理会)→收到有效报文→挂号_2→收到有效报文→挂号_3→收到有效报文溢 出。

这个流程里面,我们没有考虑从 FIFO 读出报文的情况,实际情况是:我们必须在 FIFO 溢 出之前,读出至少 1 个报文,否则下个报文到来,将导致 FIFO 溢出,从而出现报文丢失。每读 出 1 个报文,相应的挂号就减 1,直到 FIFO 空。CAN 接收流程如图 37.2.1.13 所示:FIFO 接收到的报文数,我们可以通过查询 CAN_RFxR 的 FMP 寄存器来得到,只要 FMP 不为 0,我们就可以从 FIFO 读出收到的报文。

STM32 的 CAN 位时序特性

接下来,我们简单看看 STM32 的 CAN 位时间特性,STM32 的 CAN 位时间特性和之前我 们介绍的 CAN 协议中,稍有点区别。STM32 把传播时间段和相位缓冲段 1(STM32 称之为时 间段 1)合并了,所以 STM32 的 CAN 一个位只有 3 段:同步段(SYNC_SEG)、时间段 1(BS1) 和时间段 2(BS2)。STM32 的 BS1 段可以设置为 1~16 个时间单元,刚好等于我们上面介绍的 传播时间段和相位缓冲段 1 之和。STM32 的 CAN 位时序如图 37.2.1.14 所示:

图中还给出了 CAN 波特率的计算公式,我们只需要知道 BS1 和 BS2 的设置,以及 APB1 的时钟频率(一般为 36Mhz),就可以方便的计算出波特率。比如设置 TS1=8、TS2=7 和 BRP=3, 在 APB1 频率为 36Mhz 的条件下,即可得到 CAN 通信的波特率=36000/[(9+8+1)*4]=500Kbps。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/182623.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

保姆级 Keras 实现 YOLO v3 一

保姆级 Keras 实现 YOLO v3 一 一. YOLO v3 总览二. 特征提取网络特征提取网络代码实现 三. 特征融合特征融合代码实现 四. 网络输出模型输出代码实现 五. 网络模型代码实现六. 代码下载 如果要给 YOLO 目标检测算法一个评价的话, 就是快和准, 现在已经到了 v8, 但是我为什么还…

【考研数据结构代码题7】求一元多项式之和

题目:编写一个算法,求一元多项式之和 考纲:一元多项式的表示与相加 题型:代码填空或算法设计 难度:★★★ 参考代码 typedef struct node{float coef;//系数int exp;//次数struct node *next; }polynode; polynode *…

Volcano3D绘制3D火山图

一边学习,一边总结,一边分享! 本期教程内容 **注:**本教程详细内容 Volcano3D绘制3D火山图 一、前言 火山图是做差异分析中最常用到的图形,在前面的推文中,我们也推出了好几期火山图的绘制教程&#xff0…

红队攻防实战之内网穿透隐秘隧道搭建

别低头,皇冠会掉;别流泪,贱人会笑。 本文首发于先知社区,原创作者即是本人 0x00 前言 构建内网隐蔽通道,从而突破各种安全策略限制,实现对目标服务器的完美控制。 当我们从外网成功获得攻击点的时候&…

【LeetCode】挑战100天 Day13(热题+面试经典150题)

【LeetCode】挑战100天 Day13(热题面试经典150题) 一、LeetCode介绍二、LeetCode 热题 HOT 100-152.1 题目2.2 题解 三、面试经典 150 题-153.1 题目3.2 题解 一、LeetCode介绍 LeetCode是一个在线编程网站,提供各种算法和数据结构的题目&…

ComfyUI搭建使用教程

ComfyUI 是一个基于节点流程式的stable diffusion AI 绘图工具WebUI, 你可以把它想象成集成了stable diffusion功能的substance designer, 通过将stable diffusion的流程拆分成节点,实现了更加精准的工作流定制和完善的可复现性。但节点式的工…

STM32F103C8T6第6天:adc、iic、spi、温湿度dht11在lcd1602显示

1. ADC介绍 ADC是什么? Analog-to-Digital Converter,指模拟/数字转换器 ADC的性能指标 量程:能测量的电压范围分辨率:ADC能辨别的最小模拟量,通常以输出二进制数的位数表示,比如:8、10、1…

人工智能:一种现代的方法 第十四章 概率推理

文章目录 人工智能:一种现代的方法 第十四章 概率推理本章前言14.1 不确定性问题域中的知识表示14.1.1 联合概率分布14.1.2贝叶斯网络 14.2 贝叶斯网络的语义14.2.1表示联合概率分布14.2.2 紧致性14.2.3 节点排序14.2.4 贝叶斯网络中的条件独立关系14.3 条件分布的有…

div中添加el-loading(局部loading的使用)

效果&#xff1a;在div中实现el-loading <div class"content-main">{{ hotList }}</div>getHotList(columnType) {this.$nextTick(() > {var loading this.$loading({lock: true,text: "努力加载中...",spinner: "el-icon-loading&qu…

【LeetCode刷题-回溯】-- 47.全排列II

47.全排列II 主要需要解决全排列不重复的问题&#xff0c;设定一个规则&#xff0c;保证在填第i个数的时候重复数字只会被填入一次即可&#xff0c;而在本题中&#xff0c;我们选择对原数组排序&#xff0c;保证相同的数字都相邻&#xff0c;然后每次填入的数一定是这个数所在重…

【深度学习】参数优化和训练技巧

寻找合适的学习率(learning rate) 学习率是一个非常非常重要的超参数&#xff0c;这个参数呢&#xff0c;面对不同规模、不同batch-size、不同优化方式、不同数据集&#xff0c;其最合适的值都是不确定的&#xff0c;我们无法光凭经验来准确地确定lr的值&#xff0c;我们唯一可…

问答知识库快速构建技术解析及行业实践

对话式 AI 类产品&#xff0c;已经在各行各业中实现规模化的应用。随着科技创新支撑下的高质量行业发展&#xff0c;人工智能已成为数字经济时代的核心生产力。其中对话式 AI&#xff0c;作为人工智能技术的一个分支&#xff0c;随着深度学习、预训练模型等技术的突破&#xff…

程序员接单,宝藏好平台抄底攻略清单!五大平台精选。

前阵子”双十一“购物节狂欢促销&#xff0c;各种好货清单席卷而来。 程序员购不购物我不知道&#xff0c;但是这个兼职、接单清单相信你一定用得着。 搜罗海量信息&#xff0c;整理大量数据与评价&#xff0c;挖出了5个宝藏平台&#xff0c;绝对个个精选&#xff0c;保证量大…

Python函数式编程:让你的代码更优雅更简洁

概要 函数式编程&#xff08;Functional Programming&#xff09;是一种编程范式&#xff0c;它将计算视为函数的求值&#xff0c;并且避免使用可变状态和循环。 函数式编程强调的是函数的计算&#xff0c;而不是它的副作用。 在函数式编程中&#xff0c;函数是第一类公民&a…

IDEA设置方法注释模板

目录 一.打开设置&#xff1a;File—>Settings... 二.选择Live Templates—>点击右侧 "" 号—>选择Template Group... 三.输入组名称&#xff0c;建议取容易理解的名字&#xff0c;点击OK 四.选中创建好的组&#xff0c;再次点击 "" 号&#…

二十三、RestClient操作索引库

目录 例&#xff1a;利用JavaRestClient实现创建、删除索引库&#xff0c;判断索引库是否存在 1、编写mapping映射 2、初始化JavaRestClient &#xff08;1&#xff09;导入elasticsearch的依赖 &#xff08;2&#xff09;修改elasticsearch的版本 &#xff08;3&#xf…

企业必看的大数据安全极速传输解决方案

在这个大数据时代&#xff0c;企业在享受大数据带来的便利同时&#xff0c;也面临着巨大的挑战&#xff0c;其中最主要的问题就是数据安全方面和传输方面&#xff0c;为了更好地满足企业大数据传输的需求&#xff0c;小编将深入分析企业对于大数据传输面临的挑战和风险以及大数…

飞翔的鸟游戏

一.准备工作 首先创建一个新的Java项目命名为“飞翔的鸟”&#xff0c;并在src中创建一个包命名为“com.qiku.bird"&#xff0c;在这个包内分别创建4个类命名为“Bird”、“BirdGame”、“Column”、“Ground”&#xff0c;并向需要的图片素材导入到包内。 二.代码呈现 pa…

Speaker Verification,声纹验证详解——语音信号处理学习(九)

参考文献&#xff1a; Speaker Verification哔哩哔哩bilibili 2020 年 3月 新番 李宏毅 人类语言处理 独家笔记 声纹识别 - 16 - 知乎 (zhihu.com) (2) Meta Learning – Metric-based (1/3) - YouTube 如何理解等错误率(EER, Equal Error Rate)&#xff1f;请不要只给定义 - 知…

docker部署微服务

目录 docker操作命令 镜像操作命令 拉取镜像 导出镜像 删除镜像 加载镜像 推送镜像 部署 pom文件加上 在每个模块根目录加上DockerFile文件 项目根目录加上docker-compose.yml文件 打包&#xff0c;clean&#xff0c;package 服务器上新建文件夹 测试docker-compo…