之前在文章《电动汽车动力总成解读︱模拟世界与数字世界》中提到的,我们所处的世界,是一个由用无限多种颜色、无数种音调,无数种气味绘制而成的世界,所有的这些元素都可以理解成一个模拟信号,他们是构建这个世界的元素。而CAN总线技术(Controller Area Network),类似于我们的神经系统,遍布于我们身体的各个部分,通过某种规则,与身体的各个节点之间交互,接收和发送信息,从而感受世界、改造世界。今天我们就来聊聊上80年代由BOSCH公司开发的CAN总线技术。
▼
文章结构如下:
1. 什么是CAN总线技术?
2. 为什么需要CAN总线?
3. 为什么是CAN总线被广泛应用?
4. CAN总线报文是如何传输的?(传输方式)
4.1 CAN报文/信号/物理量
4.2 模拟信号与数字信号
4.3 CAN总线物理结构
4.4 传输方式
5. CAN协议帧结构
6. OSI网络结构与AUTOSAR架构
6.1 OSI网络结构
6.2 AUTOSAR架构
7. CAN报文的发送、确认和接收
7.1 报文的发送、确认
7.2 报文的接收
1. 什么是CAN总线技术?
CAN,即Controller Area Network,二十世纪八十年代由BOSCH公司为解决现代汽车中众多ECU之间的数据交换而开发的一种单工穿行通信协议。
可以将CAN总线理解成我们的神经系统,它遍布于我们身体的各个部分,通过某种规则,与身体的各个节点之间交互,发送或接收消息。
也可以将其理解成电话会议,一旦某一节点有发送请求,该信息将输入网络,其他节点共同接收,接收节点判断是否使用该信息。
备注: 单工 , 指 同一时间,只能有一个ECU单元向总线发送数据,而其他ECU只能做为接收节点。
2. 为什么需要CAN总线?
正如之前在文章《电动汽车动力总成解读︱模拟世界与数字世界》中提到的,我们所处的世界,是一个由用无限多种颜色、无数种音调,无数种气味绘制而成的世界,所有的这些元素都可以理解成一个模拟信号,他们是构建这个世界的元素。
而人类,作为高级动物,正式通过相互交流、合作,对这个世界进行了改造。将这一概念放到汽车上:人类通过文字、声音、图像来交流,为了提升交流效率,诞生了“网络”技术;汽车不同部件之间则通过线束来实现,同样,为了提升信息交换的效率、简化系统,诞生了“总线”技术。
3. 为什么是CAN总线被广泛应用?
早期的网络结构有很多,为什么CAN总线技术得以推广应用,主要以下几点原因:
低成本
中央集成控制
鲁棒性高
高效(仲裁机制)
灵活性高
4. CAN总线报文是如何传输的?(传输方式)
4.1 CAN报文/信号/物理量
介绍之前先对CAN报文/信号/物理量的概念做下区分,三句话概括:
任何报文都可以在总线的节点之间传递
任何报文的数据字节都可以分解成信号
信号可以用物理量形式表示
4.2 模拟信号与数字信号
之前我们介绍过模拟信号与数字信号,详见文字《电动汽车动力总成解读︱模拟世界与数字世界》。
我们所处的世界,是一个由用无限多种颜色、无数种音调,无数种气味绘制而成的世界,所有的这些元素都可以理解成一个模拟信号,他们是构建这个世界的元素。ECU之间通过CAN总线的通讯过程,与人类通过音频、视频的过程是一样的,即数字量与模拟量之间的转换。
4.3 CAN总线物理结构
如下图所示为CAN总线物理结构,基本形式为: CAN_H + CAN_L + 各个节点(Nodes)。
其中,
CAN_H/CAN_L:以双绞形式缠绕;
节点:CAN收发器(Transceiver) + CAN控制器(Controller),控制器的 Tx 发送端脚、Rx 接收端脚,而收发器直接连接在双绞线上。
CAN总线上的信号,即为电压形式表现的差分信号,由 CAN_H和CAN_L两根信号线组成,分为显性电平(dominant)和隐性电平(recessive)两种类型。其中显性电平规定为逻辑0,隐性电平则为逻辑1,如下图所示。
4.4 传输方式
当CPU需要发送数据时候,CAN Controller给Transceiver传送需求的数据,CAN Transceiver将其发送给CAN 总线,通过CAN_H和CAN_L两根线实现整车各ECU节点之间的串联,接收数据类似过程。
综上,整车ECU各节点之间CAN总线的通讯方式,简单理解如下:
发送 :Transceiver 将上层传递的数据进解析成电压信号 (根据ISO 11898/ISO11519定义),并传递至BUS。
接收 : Transceiver 将BUS信号转变为二进制信号给CAN Controller;CPU将CAN Controller传送的数据进行解析、提取,经过相应运算,控制传感器和执行器。
了解了CAN总线上报文的传递方式和逻辑电平序列的应用,那么这些逻辑电平序列要如何使用呢?
5. CAN协议帧结构
为了说明上述逻辑电平序列的使用方式,需要了解CAN协议帧的结构。
CAN协议标准里对这些逻辑点评序列做了定义,使这些数据字段有了灵魂,标准中对CAN协议帧的定义有以下4种类型:
数据帧:用于发送单元向接收单元传输数据的帧
遥控帧:用于接收单元向具有相同ID的发送单元请求数据的帧
错误帧:用具当检测出错误时,向其他单元通知错误的帧
过载帧:用于接收单元通知其尚未做好接收准备的帧
简单来讲,正式通过上述对报文信号协议帧的规范,使我们ECU之间的通讯定位准确、逻辑清楚、信息完善、响应及时、鲁棒性高,限于篇幅,具体帧结构的展开形式和应用方法本文不做详细介绍,感兴趣的可以自行搜索,如有时间我也会再做总结。
通讯逻辑和方法已大致了解,那么具体要怎么实现CAN通讯功能呢?
6. OSI网络结构与AUTOSAR架构
为了满足软件的可以执行、可扩展性和安全性能等,我们引入基于OSI网络结构的AUTOSAR架构,如下图所示。
6.1 OSI网络结构
OSI网络结构定义如下,其核心目的时为了将协议、服务和接口明确区分,解决异种节点互联时的兼容性问题。
对于车规级CAN网络通讯,只对 物理层、数据链路层、应用层 做了逻辑上定义,其他暂无需关注。
物理层: 利用传输介质对数据链路层提供物理连接,负责数据流的物理传输,传输单位是0和1。
数据链路层: 在通信实体间建立数据链路联接,传输的基本单位为“帧”,可分为两部分MAC(介质访问控制子层) + LLC(逻辑链路控制子层)。
其中,MAC——规定如何在物理线路上传输帧,LLC——对在同一条网络链路上的设备之间的通信进行管理。
应用层:实现对物理层数据层数据的解析,即VCU通过哪些ID通信,报文长度,数据所代表的信号,信号含义等。
6.2 AUTOSAR架构
下图为基于OSI网络结构的AUTOSAR架构中的通讯站。可以看出,HW访问只有通过Driver实现,CAN If模块与其对接,同时,CAN If统一管理与service层的通讯,通过PduR路由到更多上层模块,减少了接口。
7. CAN报文的发送、确认和接收
7.1 报文的发送、确认
简单来讲,报文发送的过程,即用户向服务提供者发出请求(request),然后提供者向用户确认请求结果(confirm)的过程,如下图所示:
详细说明下这一过程:
Step1. BSW通过Com_SendSignal周期性调度Com模块中的Com_MainFunctionTx函数,Com模块从缓存中读取需要发送的数据;
Step2. Com模块的Com_MainFunction_Tx函数将调用PduR模块的PduR_ComTransmit函数,将数据传递给PduR
Step3. PduR模块路由到下层模块,调用CanIf模块的CanIf_Transmit函数,数据被传递至下层CanIf
Step4. CanIf模块调用Can Driver模块Can_Write函数
Step5. Can_Write函数将访问仲裁、数据长度和数据寄存器,通过Can Driver访问Can HW,将数据写入相应寄存器(通过数数据协议单元PDU)
Step6. 以POLLING作为CAN 发送的处理方式(三种,详见标准),BSW Scheduler周期性调度Can Driver模块的Can_MainFunction_Write函数
Step7. Can Driver 通过Can_MainFunction_Write函数访问Can HW中相关寄存器,读取数据供上层确认
Step8. 读取后,调用CanIf的CanIf_TxComfirmation函数,将数据上传至CanIf
Step9. CanIf调用PduR模块的PduR_TxConfirmation函数,将数据传到PduR模块
Step 10. PduR模块路由到Com模块,调用Com_TxConfirmation函数,确认发送状态。
其中1~5为发送阶段,6~10为确认阶段,其中具体的函数调用规则和定义可参见《AUTOSAR- Specification of CAN Interface》。
7.2 报文的接收
报文接收的过程,即服务提供者通知所服务用户的过程(indication),过程与上述确认过程类似,这里不做赘述。
以上就是关于CAN总线技术的基本内容,实际应用中会涉及很多细节,标准中对应章节有规范,对某一方面感兴趣或者有疑问的读者可以后台留言,欢迎交流。