一文读懂CAN总线及通信协议

2023-10-31

CAN总线的汽车

 

CAN概念

CAN控制器域网 (Controller Area Network, CAN) 的简称,是由研发和生产汽车电子产品著称的德国BOSCH公司开发了的,并最终成为国际标准(ISO11898),是ISO国际标准化的串行通信协议。是国际上应用最广泛的现场总线之一。 在北美和西欧,CAN总线协议已经成为汽车计算机控制系统和嵌入式工业控制局域网的标准总线,并且拥有以CAN为底层协议专为大型货车和重工机械车辆设计的J1939协议。近年来,其所具有的高可靠性和良好的错误检测能力受到重视,被广泛应用于汽车计算机控制系统和环境温度恶劣、电磁辐射强和振动大的工业环境。

CAN的两个ISO国际标准:

1)ISO11898 :定义了通信速率为 125 kbps~1 Mbps 的高速 CAN 通信标准,属于闭环总线,传输速率可达1Mbps,总线长度 ≤ 40米。

2)ISO11519:定义了通信速率为 10~125 kbps 的低速 CAN 通信标准,属于开环总线,传输速率为40kbps时,总线长度可达1000米。

CAN种类

1)高速CAN:

a.根据线缆的长度提供从5Kbit/s到1Mbit/s的波特率。

b.高速CAN网络在每个网络端点端接一个120欧姆的电阻。

c.电平静默为2.5V,上下限是3.5V和1.5V。

2) 容错CAN:

a.提供5Kbit/s到125Kbits/s的波特率。

b.显性时则为1V和4V。

3)单线CAN:

a.提供5Kbit/s到125Kbits/s的波特率。

b.单线CAN的波特率一般为33.3KHz。

汽车CAN网络

 

汽车CAN网络

汽车CAN总线

 

CAN组成

CAN总线的一个主要由帧信息帧ID帧数据组成。

1)帧信息:分四类,标准数据帧(汽油车、电机)、标准远程帧(少见)、扩展数据帧(广大柴油车、部分汽油车)、扩展远程帧(少见)。

2)帧ID:是CAN的一种“地址”。CAN有个特点是竞争机制帧ID越小越有占用总线资源的权利,越会优先发送。

        


CAN ID

DBC文件:车辆行业中,如果对车辆CAN总线上的每个帧ID及每个帧数据都做出了标准的解释,形成了的文件就是DBC文件。

3)帧数据:和串口相比,CAN的帧数据只有8个字节,即64个位,不会再多了。但CAN FD作为新型总线解决了仅有8字节这个问题。

4)终端电阻:CAN和RS485一样,要在终端减少差分信号的反射,如不在两个终端加电阻,信号会反弹回来影响通讯。终端电阻在CAN总线上要有两个,阻值为120欧姆,并联,最远的终端一边一个。如果有多个节点的话,终端电阻应适当加大。

5)波特率:常见的车辆波特率有500K,250K,125K,100K。

CAN总线标准

ISO标准

 

CAN标准分为底层标准(物理层和数据链路层)和上层标准(应用层)两大类

  • ISO 11898-1 – CAN协议
  • ISO 11898-2 – CAN高速物理层
  • ISO 11898-3 – CAN低速可容错物理层
  • ISO 11898-4 – 时间触发CAN
  • ISO 11898-5 – “低功率模式高速介质存取单元” – 目前处于起草阶段
  • ISO 11519-2 – 已过时,被11898-3取代。
  • ISO 14230 – “关键字协议2000” – 定义非CAN串行线路诊断的若干部分。
  • ISO 15765 – CAN总线上定义诊断的标准 – 本质上是CAN总线上的关键字协议2000。
  • J1939 – 卡车和客车领域应用最广泛的基于CAN的高层协议,由SAE定义。J1939分成几个部分,描述物理层、数据链路层、网络管理和大量预定义的报文。
  • ISO 11783 – 与J1939相似,但用于农业领域(诸如拖拉机)
  • ISO 11992 – 定义卡车和拖车之间的接口
  • NMEA 2000 – 基于J1939的协议,用于海事领域。由NMEA委员会定义。

如果没有详细说明谈论中所使用哪种标准,通常其默认是指ISO 11898-1定义的数据链路层协议和ISO 11898-2定义的物理层。

底层标准:

CAN底层标准都基本一样,涵盖OSI模型中的物理层和数据链路层,与ISO/OSI模型的对应关系如下图所示:

对应关系

 

  • ISO 11898-1:数据链路层协议,描述CAN总线的基本架构,定义不同CAN总线设备在数据链路层通信方式
  • ISO 11898-2:高速CAN总线物理层协议,最高数据传输速率 1Mbps,应用为两线平衡式信号(CAN_H, CAN_L)
  • ISO 11898-3:定义低速CAN总线(LS-CAN, Fault-Tolerant CAN)物理层标准,数据传输速率在 5Kbps ~ 125Kbps 。Fault-Tolerant是指总线上一根传输信号失效时,依靠另外的单根信号也可以通信
  • ISO 11898-4:定义CAN总线中的时间触发机制(Time-Triggered CAN, TTCAN),定义与ISO 11898-1 配合的帧同步实体,实现汽车ECU之间基于时间触发的通信方式。

上层标准:

不同应用领域或制造商有不同的做法,没有统一的国际标准

上层协议对比

 

CAN的帧种类(四种帧类型)

1)数据帧

用于发送单元向接收单元传送数据的帧。

数据帧的帧结构图:

数据帧

 

SOF:表示数据帧开始;(1 bit),发出一个显性位边沿,网络节点以此开始同步

ID:标准格式11 bit,扩展格式29 bit包括Base ID(11 bit)和Extended IDr(18 bit),该区段标识数据帧的优先级,数值越小,优先级越高;

RTR:远程传输请求位,0时表示为数据帧,1表示为远程帧,也就是说RTR=1时,消息帧的Data Field为空;(1 bit)

IDE:(1 bit)标识符扩展位,0时表示为标准格式,1表示为扩展格式;扩展帧和标准帧格式不同,不能存在于同一can网络

DLC:数据长度代码,0-8表示数据长度为0~8 Byte;(4 bit)

Data Field:数据域;(0~8 Byte)

CRC (15 bit):

  • 校验域,从sof到数据场的所有数据进行encode
  • 由发送方填
  • 校验算法G(x) = x15 + x14 + x10 + x8 + x7 + x4 + x3 + 1;(15 bit)

DEL:校验域和应答域的隐性界定符;(1 bit)

ACK:(1 bit)

  • 应答域,确认数据是否正常接收,所谓正常接收是指不含填充错误、格式错误、 CRC 错误。
  • 发送节点将此位为1,由接收方进行确认,收到消息给出一个显性位0
  • 如果一个节点都没有确认收到消息,发送方监听此位为隐形位就会报错

SRR:替代远程请求位,在扩展格式中占位用,必须为1;(1 bit)

EOF:连续7个隐性位(1)表示帧结束;(7 bit)

ITM(3 bit):

  • 帧间空间,Intermission (ITM),又称Interframe Space (IFS),连续3个隐性位,但它不属于数据帧。
  • 帧间空间是用于将数据帧和远程帧与前面的帧分离开来的帧。数据帧和远程帧可通过插入帧间空间将本帧与前面的任何帧(数据帧、遥控帧、错误帧、过载帧)分开。过载帧和错误帧前不能插入帧间空间。

2)远程帧

用于接收单元向具有相同标识符的发送单元请求数据的帧。

远程帧与数据帧的帧结构类似,区别:

  • 1、数据帧的 RTR 值为“0”,远程帧的 RTR 值为“1”。
  • 2、远程帧没有数据块。
  • 3、远程帧的 DLC 块表示请求发送单元发送的数据长度。

格式图

远程帧

 

当总线上具有相同标识符的数据帧和远程帧同时发送时,由于数据帧的 RTR 位是显性的,数据帧将在仲裁中赢得总线控制权。

3)错误帧

用于当检测出错误时向其它单元通知错误的帧。

错误帧的帧结构由错误标志和错误界定符构成。

错误标志:6bit,

错误标志

 

错误界定符:由8bit的隐性位构成。

4)过载帧

接收单元通知发送单元它尚未完成接收准备。

发送过载帧的两种情况:

1、接收单元条件的制约,要求发送节点延缓下一个数据帧或远程帧的传输。

2、帧间空间(Intermission)的 3 bit 内检测到显性位。

每个节点最多连续发送两条过载帧,过载帧由过载标志和过载界定符(8 个隐性位)构成。

过载帧

 

数据帧和远程帧比较:

比较

 

CAN总线仲裁

仲裁优先级:标识符值越小,消息的优先级越高

线与逻辑:只有节点发送的全是隐性,总线电平才表现为隐性

所有发送节点在发送数据的同时,也检测总线上的电平状态,逐位对比总线上电平与自身发送的电平。

  • 1)发 0 出现 1 :报错。
  • 2)发 0 出现 0 :继续。
  • 3)发 1 出现 1: 继续。
  • 4)发 1 出现 0: 竞争失败,转为接收方。

发送自检

 

如下图,竞争失败的C节点会自动在检测到总线空闲的第一时间再次尝试发送。

CAN 节点A和C同时发送数据帧,CAN总线根据优先级仲裁,C失去权力

 

CAN条件接收

在CAN总线上消息是广播式的,节点可以通过设置控制器中过滤码(Filter Code )和掩码(Mask Code),再检验总线上消息的标识符,来判断是否接收该消息,对于掩码,“1”表示该位与本节点相关,“0”表示该位与本节点不相关。

CAN-BUS数据流程

 

STM32的can过滤码

 

位填充

CAN总线采用NRZ编码,没有单独时钟线,优点是效率高,但却不易区分哪里是bit开始,哪里是bit结束。因此为确保在同步通信过程中有足够的电平跳变,规范中应用到位填充机制,即在每连续 5个相同电平后插入1个反相电平,接收节点在收到消息后自动将填充位删除。

数据帧位填充比较图

 

在帧内除了CRC界定符、ACK域和EOF外,其余部分均应用到位填充机制,在应用到位填充的域,检测到连续6个显性位或隐性位均视为报错。

CAN错误检验

CRC错误

1)在发送消息时,发送节点会根据特定的多项式计算出由数据帧SOF位到数据域最末位的Checksum值,并将该值放在数据帧的CRC域,随着数据帧广播到总线上。

2)接收节点在收到数据后,应用同样的多项式计算Checksum值,并与收到的Checksum值对比。如果两者一致,正常接收;如果不一致,则舍弃该消息,并发送错误帧请求发送节点重传消息。

应答错误(ACK Error)

接收方会在收到消息后在ack应答位给出一个显性电平,如果发送方检测到该位为隐性,则报错。

格式错误(Form Error)

检测出与固定格式的位段相反的格式时所检测到的错误,如检测crc界定符和ack界定符以及eof区域是否出现显性位。

位错误(Bit Error)

比较输出电平和总线电平(不含填充位),当两电平不一样时所检测到的错误。如发送显性位,但总线是隐性位就报错。

填充错误(Stuff Error)

在需要位填充的段内,连续检测到 6 位相同的电平时所检测到的错误。

CAN总线错误检测机制

CAN总线上的每个节点控制器都会检测消息是否出错,如果节点发现消息出错,它将发送错误标志,从而打断总线上正常的数据传输。总线上其它没有发现原始消息错误的节点,在收到错误标志后将采取必要的措施,比如舍弃当前总线上的消息。

CAN节点内部有两种错误状态计数器 :

  • 1)TEC /Transmit Error Counter,发送错误状态计数器,出现一次错误该计数器值 +8
  • 2)REC /Receive Error Counter,接收错误状态计数器,出现一次错误该计数器值 +1
  • 3)消息成功发送或接收一次,对应的 TEC 或 REC 值相应 -1

                                                        错误计数

CAN规范定义了节点的 3 种错误状态:

  • 1) 主动错误:正常状态,在此状态下,节点可以发送所有类型的帧,包括错误帧;发现错误后会很积极主动地上报错误。
  • 2)被动错误:节点可以发送除错误帧以外的所有帧;TEC or REC 计数超过127就进入此状态;此时,该节点发现错误后只会发送6个隐性位,不会把错误广播出去。并且,发送连续帧时,中间必须间隔8bit的延缓时间。
  • 3)总线关闭:节点被控制器从总线上隔离;或者TEC大于255,就会进入这个状态,需要重启,或者等待128个11位隐性位电平。

CAN总线错误检测机制

 

CAN总线协议入门.pdf

CAN总线C源码与资料.rar

CAN总线C源码与资料,can分析仪总线电机同步启动源程序

CAN总线协议应用手册.pdf

CAN总线协议应用手册

can-utils.zip

CAN工具,包含显示,记录,生成和重放CAN流量的基本工具,CAN内核网关配置,CAN总线测量和测试,ISO-TP工具,日志文件转换器,串行线路规范配置,CMake项目生成器等源代码

CAN Bus Shield - MCP2515&MCP2551.zip

基于arduino的can 总线协议源码和应用案例代码

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

一文读懂CAN总线及通信协议 的相关文章

  • 解读startx

    X 的虚拟终端下的蜂鸣声可通过 xset b off 关闭 此命令 可放在 startx 的配置文件 HOME xinitrc 中 X 的虚拟终端下的蜂鸣声可通过 xset b off 关闭 此命令 可放在 startx 的配置文件 HOM

随机推荐

  • 07. 实战:Python正则法抓取某网站2022必看片迅雷种子

    目录 前言 URL 在评论区 URL 在评论区 URL 在评论区 目的 URL 在评论区 URL 在评论区 URL 在评论区 思路 URL 在评论区 URL 在评论区 URL 在评论区 代码实现 第一步 先导包 第二步 请求源代码 第三步
  • iwebsec靶场 SQL注入漏洞通关笔记7- 空格过滤绕过

    系列文章目录 iwebsec靶场 SQL注入漏洞通关笔记1 数字型注入 mooyuan的博客 CSDN博客 iwebsec靶场 SQL注入漏洞通关笔记2 字符型注入 宽字节注入 mooyuan的博客 CSDN博客 iwebsec靶场 SQL
  • Linux实验:Shell编程

    对思考题4 8 进行编辑 然后执行 功能 输入的所有参数逆序输出显示 对思考题 4 14 进行编辑 然后执行 功能 显示裴波那契数列前10项及它们的和 对思考题4 18 进行编辑 然后执行 功能 输出输入字符串中抽取的第n个字符至第m个字符
  • 【python】考前复习,python基础语法知识点整理

    文章目录 1 常量与表达式 2 变量和数据类型 创建变量 数据类型 动态类型 数据类型的转换 3 注释 4 字符串 字符串的定义方式 字符串的拼接 字符串的格式化 字符串格式化的精度控制 字符串的格式化 对表达式进行格式化 5 从控制台输入
  • 【Android Jetpack】新一代导航管理——Navigation

    目录 前言 使用Navigation 创建导航视图 添加页面 添加导航 添加导航宿主 实现导航 原理解析 NavHostFragment 支持ToolBar 总结 前言 不知道小伙伴们是否注意到 用AS创建一个默认的新项目后 MainAct
  • 软件测试——性能测试

    性能测试基础 为什么要进行性能测试 WHY 最重要 应用程序是否能够很快的响应用户的要求 应用程序是否能处理预期的用户负载并有盈余能力 应用程序是否能处理业务所需要的事务数量 在预期和非预期的用户负载下 应用程序是否稳定 是否能够确保用户在
  • ISAAC WORKSPACE FILE

    Copyright 2019 NVIDIA CORPORATION All rights reserved NVIDIA CORPORATION and its licensors retain all intellectual prope
  • [需求管理-2]:什么是需求以及需求的收集与识别

    作者主页 文火冰糖的硅基工坊 文火冰糖 王文兵 的博客 文火冰糖的硅基工坊 CSDN博客 本文网址 需求管理 2 什么是需求以及需求的收集与识别 文火冰糖的硅基工坊的博客 CSDN博客 目录 第1章 什么是需求识别 第2章 需求的来源 2
  • 算法题 货仓选址(Python)

    题目 在一条数轴上有 N 家商店 它们的坐标分别为 A1 AN 现在需要在数轴上建立一家货仓 每天清晨 从货仓到每家商店都要运送一车商品 为了提高效率 求把货仓建在何处 可以使得货仓到每家商店的距离之和最小 输入格式 第一行输入整数N 第二
  • File类读取文件---本地文件和网络文件

    读取本地文件 File file new File resource audio 5 mp3 InputStream in null try 一次读多个字节 byte tempbytes new byte 100 int byteread
  • Vue项目开发环境安装、项目构建运行、打包部署详解

    Vue项目开发环境安装 项目构建运行 打包部署详解 背景 Vue工程化项目环境配置还是比较麻烦的 本篇来详细的记录下从0开始的安装 构建 打包 运行全过程 整体步骤 第一 安装Node js 这个是前端工程化项目运行的基础环境 第二 安装V
  • Java 网络编程 —— RMI 框架

    概述 RMI 是 Java 提供的一个完善的简单易用的远程方法调用框架 采用客户 服务器通信方式 在服务器上部署了提供各种服务的远程对象 客户端请求访问服务器上远程对象的方法 它要求客户端与服务器端都是 Java 程序 RMI 框架采用代理
  • 【程序员面试系列】算法题练习-汇总(含华为OD机试题目)

    做个4月算法刷题集合 方便复习巩固 欢迎交流探讨 题库源于牛客网 ACM模式 语言 Java Python 题库链接 HJ1 字符串最后一个单词的长度 描述 计算字符串最后一个单词的长度 单词以空格隔开 字符串长度小于5000 注 字符串末
  • 如何修复损坏的word

    Word是许多人在日常工作中经常使用的软件 但有时它可能会出现意外的崩溃或文档损坏 这对于你正在编辑的文件和工作的进展都会产生重大影响 但是 你不需要过于担心 因为还是有一些方法可以通过修复Word文档中的损坏来解决这个问题 那么如何修复损
  • TCP三次握手,两次可以吗?

    这个问题网络上的回答超级多 众说纷纭 以 RFC 793 来回答这个问题可能更加准确 Reliability The TCP must recover from data that is damaged lost duplicated or
  • C语言——qsort()函数用法

    qsort函数简介及用法 一 qsort 函数的简介 二 qsort 函数实例 1 排序整形数组 2 排序double型数组 3 排序字符型数据 4 结构体类型数据排序 三 使用冒泡排序模拟qsort 函数 一 qsort 函数的简介 qs
  • ' requires string as left operand, not int' aria-label='TypeError: 'in ' requires string as left operand, not int'> TypeError: 'in ' requires string as left operand, not int

    报错 Traceback most recent call last File D PyCharm 5 0 3 WorkSpace 2 NLP 9 DL在NLP中的应用 4 VectorizerVisualization py line 4
  • docker和k8s的关系

    docker和k8s的关系 过去十年间 云计算的技术得到了长足的发展 越来越多的人开始了解 云原生 技术 以著名的云原生计算基金会 CNCF Cloud Native Computing Foundation 为首 各大企业和社区都开始发展
  • javascript:;与javascript:void(0)使用介绍

    最近看了好几个关于 a 标签和javascript void 0 的帖子 谨记于此 以资查阅 注 以下代码未经全面测试 但每一种方法可能会出现的情况都基本做了说明 在做页面时 如果想做一个链接点击后不做任何事情 或者响应点击而完成其他事情
  • 一文读懂CAN总线及通信协议

    CAN总线的汽车 CAN概念 CAN是控制器域网 Controller Area Network CAN 的简称 是由研发和生产汽车电子产品著称的德国BOSCH公司开发了的 并最终成为国际标准 ISO11898 是ISO国际标准化的串行通信