CAN总线简介

CAN 是 Controller Area Network 的缩写(以下称为 CAN),是 ISO国际标准化的串行通信协议。

历史背景

CAN 最初出现在80年代末的汽车工业中,由德国 Bosch 公司最先提出。当时,由于消费者对于汽车功能的要求越来越多,而这些功能的实现大多是基于电子操作的,这就使得电子装置之间的通讯越来越复杂,同时意味着需要更多的连接信号线。
在1980年代初期,博世的工程师正在评估现有的串行总线系统,以探讨其在汽车中的可能用途。由于没有可用的网络协议能够满足汽车工程师的要求,因此Uwe Kiencke于1983年开始开发新的串行总线系统。
新的总线协议主要是要增加新的功能 — 减少线束不是CAN发展背后的驱动力。
1986年2月,CAN诞生了:在底特律的SAE大会上,新的总线系统被称为“Automotive Serial Controller Area Network(汽车串行控制器局域网)”。Uwe Kiencke,Siegfried Dais和Martin Litschel介绍了多主网络协议。它基于一种非破坏性仲裁机制,该机制允许总线访问具有最高优先级的帧而没有任何延迟。没有中心控制器。此外,CAN之父(上述人员以及博世员工Wolfgang Borst,Wolfgang Botzenhard,Otto Karl,Helmut Schelling和Jan Unruh)已经实现了几种错误检测机制。错误处理还包括自动断开故障总线节点,以保持其余节点之间的通信。传输的帧不是由帧发送器或帧接收器的节点地址(几乎在所有其他总线系统中)识别的,而是由它们的内容识别的。表示帧有效载荷的标识符,还具有指定帧在网络段内的优先级。
随后,许多介绍该创新通信协议的演讲和出版物,直到1987年中期(比计划提前两个月),英特尔才交付了第一款CAN控制器芯片82526。这是CAN协议的第一个硬件实现。在短短四年内,一个想法就变成了现实。此后不久,飞利浦半导体推出了82C200。CAN控制器的这两个最早的祖先在接受过滤和帧处理方面有很大的不同。一方面,与飞利浦选择的BasicCAN实施相比,英特尔所青睐的FullCAN概念要求所连接的微控制器的CPU负载更少。另一方面,FullCAN设备在可以接收的帧数方面受到限制。BasicCAN控制器还需要更少的硅。在当今的CAN控制器中,实现了接受过滤和帧处理这两种概念的混合。这使BasicCAN和FullCAN的误导性术语过时了。
现在,CAN 的高性能和可靠性已被认同,并被广泛地应用于工业自动化、船舶、医疗设备、工业设备等方面。

发展阶段

  • 1986年发布CAN1.0。
  • 1991年博世发布CAN2.0规范,分为CAN2.0A(11位标识符)和CAN2.0B(11+18=29位标识符)。
  • 1993年ISO组织发布国际标准ISO11898(高速应用)和ISO11519(低速应用)规范:
    1. ISO11898-1 涵盖数据链路层。
    2. ISO 11898-2 涵盖高速CAN的CAN物理层(经典CAN速度1Mbps,CAN FD 5Mbps)。
    3. ISO 11898-3 涵盖低速、容错CAN的物理层(速度125kbps)。
    4. 后续推出ISO 11898-4 -5 和-6标准。
  • 2012年博世发布CAN FD 1.0(速度2Mbps,使用加强版CAN PHY的CAN FD-SiC可以做到5-8Mbps)。
  • 2014,Infineon 开发出支持CAN FD
  • 2015,ISO 组织发布CAN FD 标准(ISO 11898-1 )
  • 2018年发布第三代CAN数据链路层协议CAN XL,速度提升至10Mbps,兼容CAN FD。

帧格式

Classic CAN和CANFD帧长度
不管是Classic CAN还是CANFD,其帧结构都由以下7个段组成

  • SOF;
  • 仲裁字段(包含标识符字段和部分格式字段);
  • 控制字段(包含 DLC 字段和部分格式字段);
  • 数据字段(包含 LLC 数据字段)
  • CRC 字段
  • ACK 字段;
    在这里插入图片描述
    在这里插入图片描述

SOF:帧起始

  • 标识一个数据帧的开始,用于同步
  • 固定格式:一个显性位
  • 只有在总线空闲期间,节点才能够发送SOF

ID:标识符

  • 唯一确定一条报文
  • 表明报文的含义,可以包含报文的源地址和目标地址
  • 确定报文的仲裁优先级,ID 数值越小,优先级越高
  • 标准帧:11位;扩展帧:29位

RRS

  • 对应传统CAN报文RTR位
  • CAN FD 没有定义远程帧
  • 发送节点发送显性位

IDE

  • 用于区分标准帧和扩展帧
  • 标准帧,IDE=0(11 位ID)
  • 扩展帧,IDE=1(29 位ID)

FDF

  • 用于区分普通CAN报文和CAN FD报文
  • CAN 报文,FDF=0
  • CAN FD 报文,FDF=1
  • 不用于仲裁
  • 对于同一ID 值只能分配给Classic CAN 报文或者FD 报文

res

  • 保留位
  • 当前置0

BRS(Bit Rate Switch)

  • 速率切换指示位
  • BRS=1 ,进行速率切换
  • BRS=0 ,不进行速率切换

ESI(Error State Indicator)

  • 错误状态指示
  • ESI=0 ,处于主动错误状态的节点
  • ESI=1 ,处于被动错误状态的节点

DLC

在这里插入图片描述

数据场

  • 具有0-64个字节长度,由DLC确定
  • 包含CAN数据帧发送的内容

CRC

在这里插入图片描述

CRC界定符(DEL)

  • 界定CRC序列
  • 1~2位(相位偏移引起)
  • 在界定符的第一位进行速率切换

ACK

  • 确定报文被至少一个节点正确接收
  • 发送节点发送隐性位,接收节点正确接收后发送显性
  • FD报文中所有节点最多可正确接收两位显性ACK

ACK界定符(DEL)

  • 界定ACK
  • 固定格式,1个隐性位

EOF

  • 表示数据帧结束
  • 固定格式,7个连续的隐性位

CAN 与ISO CAN FD 报文格式对比( 标准帧)

在这里插入图片描述

CAN 与ISO CAN FD 报文格式对比( 扩展帧)

在这里插入图片描述

Classic CAN Standard Frame标准帧(不考虑位填充)共:108Bit
帧起始(1bit)、仲裁段(12bit)、控制段(6bit)、数据段(8×8bit)、循环冗余码段(16bit)、应答段(2bit)和帧结束(7bit)

Classic CAN Extended Frame扩展帧(不考虑位填充)共:128Bit
帧起始(1bit)、仲裁段(32bit)、控制段(6bit)、数据段(8×8bit)、循环冗余码段(16bit)、应答段(2bit)和帧结束(7bit)

CANFD Standard Frame标准帧(不考虑位填充;DLC = 8)共:117Bit
帧起始(1bit)、仲裁段(12bit)、控制段(9bit)、数据段(8×8bit)、循环冗余码段(22bit)、应答段(2bit)和帧结束(7bit)

CANFD Standard Frame标准帧(不考虑位填充;DLC = 64)共:569Bit
帧起始(1bit)、仲裁段(12bit)、控制段(9bit)、数据段(64×8bit)、循环冗余码段(26bit)、应答段(2bit)和帧结束(7bit)

CANFD CAN Extended Frame扩展帧(不考虑位填充;DLC = 8)共:136Bit
帧起始(1bit)、仲裁段(32bit)、控制段(8bit)、数据段(8×8bit)、循环冗余码段(22bit)、应答段(2bit)和帧结束(7bit)

CANFD CAN Extended Frame扩展帧(不考虑位填充;DLC = 64)共:588Bit
帧起始(1bit)、仲裁段(32bit)、控制段(8bit)、数据段(64×8bit)、循环冗余码段(26bit)、应答段(2bit)和帧结束(7bit)

单个帧的“负载率”
对Classic CAN Standard Frame标准帧来说,发送一帧实际长度(不考虑位填充;帧间隔3Bit;DLC = 8):108+3=111Bit;

比特率/波特率一个Bit的位时间单个帧的“负载率”
250 Kbps4000纳秒((111 * 4000纳秒) / 1秒) *100%= 0.0444%
500 Kbps2000纳秒((111 * 2000纳秒) / 1秒) *100%= 0.0222%
1 Mbps1000纳秒((111 * 1000纳秒) / 1秒) *100%= 0.0111%

对Classic CAN Extended Frame扩展帧来说,发送一帧实际长度(不考虑位填充;帧间隔3Bit;DLC = 8):
128+3=131Bit;

比特率/波特率一个Bit的位时间单个帧的“负载率”
250 Kbps4000纳秒((131 * 4000纳秒) / 1秒) *100%= 0.0524%
500 Kbps2000纳秒((131 * 2000纳秒) / 1秒) *100%= 0.0262%
1 Mbps1000纳秒((131 * 1000纳秒) / 1秒) *100%= 0.0131%

对CANFD Standard Frame标准帧来说,发送一帧实际长度(不考虑位填充;帧间隔3Bit;DLC = 8;启用BRS位加速):117+3=120Bit
其中:

  • 29Bit使用仲裁段波特率:1位SOF段,12位仲裁段,1位IDE,1位FDF,1位R0,1位BRS,2位ACK段,7位EOF段,3位帧间隔;
  • 91Bit使用数据段波特率;1位ESI,4位DLC,64位数据段,22位CRC段。
比特率/波特率一个Bit的位时间单个帧的“负载率”
仲裁段500 Kbps2000纳秒((29 * 2000纳秒) / 1秒) *100%= 0.0058%
数据段2 Mbps500纳秒((91 * 500纳秒) / 1秒) *100%= 0.00455 %
单个帧的“负载率”0.01035%

对CANFD Standard Frame标准帧来说,发送一帧实际长度(不考虑位填充;帧间隔3Bit;DLC = 64;启用BRS位加速):569+3=572Bit;
其中:

  • 29Bit使用仲裁段波特率:1位SOF段,12位仲裁段,1位IDE,1位FDF,1位R0,1位BRS,2位ACK段,7位EOF段,3位帧间隔;
  • 543Bit使用数据段波特率;1位ESI,4位DLC,512位数据段,26位CRC段。
比特率/波特率一个Bit的位时间单个帧的“负载率”
仲裁段500 Kbps2000纳秒((29 * 2000纳秒) / 1秒) *100%= 0.0058%
数据段2 Mbps500纳秒((543 * 500纳秒) / 1秒) *100%= 0.02715%
单个帧的“负载率”0.03295%

对CANFD Extended Frame扩展帧来说,发送一帧实际长度(不考虑位填充;帧间隔3Bit;DLC = 8;启用BRS位加速):136+3=139Bit;
其中:

  • 48Bit使用仲裁段波特率:1位SOF段,32位仲裁段,1位FDF,1位R0,1位BRS,2位ACK段,7位EOF段,3位帧间隔;
  • 91Bit使用数据段波特率;1位ESI,4位DLC,64位数据段,22位CRC段。
比特率/波特率一个Bit的位时间单个帧的“负载率”
仲裁段500 Kbps2000纳秒((48 * 2000纳秒) / 1秒) *100%= 0.0096%
数据段2 Mbps500纳秒((91 * 500纳秒) / 1秒) *100%= 0.00455%
单个帧的“负载率”0.01415%

对CANFD Extended Frame扩展帧来说,发送一帧实际长度(不考虑位填充;帧间隔3Bit;DLC = 64;启用BRS位加速):588+3=591Bit;
其中:

  • 48Bit使用仲裁段波特率:1位SOF段,32位仲裁段,1位FDF,1位R0,1位BRS,2位ACK段,7位EOF段,3位帧间隔;
  • 543Bit使用数据段波特率;1位ESI,4位DLC,512位数据段,26位CRC段。
比特率/波特率一个Bit的位时间单个帧的“负载率”
仲裁段500 Kbps2000纳秒((48 * 2000纳秒) / 1秒) *100%= 0.0096%
数据段2 Mbps500纳秒((543 * 500纳秒) / 1秒) *100%= 0.02715%
单个帧的“负载率”0.03675%

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

android仿assistivetouch悬浮窗实现(带功能实现)

一、悬浮窗点击后的界面: 主要有四个功能,返回、应用程序、退出和主界面。其他功能也可以类似添加。 界面布局代码就不贴出来了,源码(切记需要签名才能让功能实现):下载地址 二、主要是检测系统启动或者a…

动态规划法例题

第一个空,用手工计算,可以用贪心法 先选择价值最大的物品,有两个价值是6的物品,重量合计246 剩余4个空间,只能放重量为2的物品,一共是66315 第二个空,需要将所有物品都放进背包舱室&#xff…

基于Python的量化交易回测框架Backtrader初识记录(一)

版权声明:本文为博主原创文章,如需转载请贴上原博文链接:基于Python的量化交易回测框架Backtrader初识记录(一)-CSDN博客 前言:近期以来,对股市数据获取及预处理算是告一段落,下一步…

OpenCV绘图函数(5)绘制标记函数drawMarker()的使用

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 cv::drawMarker 函数在 OpenCV 中用于在一个给定的位置上绘制标记。目前支持几种不同的标记类型,具体信息可以参考 MarkerTypes 函数…

【C++ | 设计模式】观察者模式的详解与实现

1.概念 观察者模式(Observer Pattern)是一种行为型设计模式,它的核心思想是定义对象间的一对多依赖关系,当一个对象的状态发生变化时,所有依赖于它的对象都会收到通知并自动更新。这个模式在现实生活中非常常见&#…

Selenium的四种部署方式详解

关于selenium 的部署,我在网上找了很多,基本上都没有提到或是说的比较清晰的。当时我一直有个困惑:测试的脚本代码,是放在跟浏览器同一台机器上呢,还是放在Application Server上? 在官方开发文档中&#x…

从0开始深度学习(2)——自动微分

1 微积分 1.1 导数和微分 略 1.2 偏导数 略 1.3 梯度(gradient) 1.3.1 定义 对于一个多变量函数 f ( x 1 , x 2 , … , x n ) f\left(x_{1}, x_{2}, \ldots, x_{n}\right) f(x1​,x2​,…,xn​)其中点 a ( a 1 , a 2 , … , a n ) \mathbf{a}(a_…

YGG深海传奇,创造财富无限可能!

随著区块链技术的创新与游戏产业的深度融合,GameFi赛道迅速崛起,成为全球投资者与玩家瞩目的新兴领域。 成立于2020年的Yield Guild Games(YGG),作为全球区块链游戏领域的先锋公会之一,也加入到向去中心化经济模式的转型浪潮当中。…

E. Sheep Eat Wolves

https://codeforces.com/gym/104869/problem/E 赛时队友想贪心,贪不了一点,我想了数学办法每次都送固定的发现送过去就不满足了 赛后补,暴力做O(n4) 至少要几次才能把安全所有羊送到对岸去 考虑最短路,bfs,用数组存下所有状态 …

17:4层板层叠设置

层叠设置参考PCB专栏 设置平面内缩 GND内缩设置20mil0.508mm 电源层内缩设置要比GND内缩大,设置40mil1mm

米家商城主题 html 页面源码分享,可用于网页设计作业

使用技术: HTML, CSS , Javascript 项目亮点: 1. 仿照米家商城页面布局所做的页面样式结构 2. 首页放置了可自动切换的轮播图 3. 登录页有表单结构,并且有切换的动画效果 4. 包含实时的动态时间,使用 js 实现 5. 页面布局清…

Datawhale X 李宏毅苹果书AI夏令营深度学习详解入门Task02

本文了解深度学习详解中的线性模型 本文了解深度学习详解中的线性模型将围绕梯度下降优化、线性模型的局限性、改进模型以及深度学习模型等关键要点展开讨论。 一、梯度下降优化 梯度下降是深度学习中常用的优化算法,它通过不断调整模型的参数,使得损失函…

axios发送post请求实例

在body中的数据格式又有两种,一种是 json 数据格式,另一种是 字符串。具体要用哪种格式取决于后端入参的格式。 如果后端接收json数据类型,post 的 headers 需要设置 { ‘content-type’: ’application/json’ },传给后端的数…

【王树森】BERT:预训练Transformer模型(个人向笔记)

前言 BERT:Bidirectional Encoder Representations from TransformerBERT是用来预训练Transformer模型的encoder的本节课只讲述主要思想BERT用两个主要思想来训练Transformer的encoder网络:①随机遮挡单词,让encoder根据上下文来预测被遮挡的…

Fine-Grained Egocentric Hand-Object(中文翻译)

精细化自我中心手-物体分割: 数据集、模型(model)与应用 灵芝张1, 盛昊周1, 西蒙斯滕特 $ {}^{2} $, 和健博石 $ {}^{1} $ 摘要。 自我中心视频提供了高保真度建模人类行为的细粒度信息。手和交互对象是理解观众行为和意图的一个关键方面。…

掌握 JavaScript 解构赋值的指南

JavaScript 的解构赋值是一种从数组 or 对象中提取值并将其赋给变量的语法。这种语法让我们从复杂的数据结构中提取数据变得简洁和易读。解构赋值可以用在数组、对象以及嵌套结构中。 解构是:使用 ES6 的一种语法规则,将一个对象或数组的某个属性提取到…

JavaSE-递归法解决二分查找、快速排序

704. 二分查找https://leetcode.cn/problems/binary-search/ package demo;public class BinarySearch {public static void main(String[] args) {BinarySearch brnew BinarySearch();System.out.println(br.search(new int[]{1, 2, 3, 4, 5, 6, 7, 8, 9}, 8));}public int s…

[Tools: LoRA] Diffusers中Stable Diffusion的实现

实现底层原理 Diffusers中的Attention操作实现在AttnProcessor类(diffusers.models.attention_processor.py),里面定义了单次Attention操作。添加LoRA,本质上是用LoRAAttnProcessor类替换AttnProcessor类。LoRAAttnProcessor中新…

浅谈如何入门微信小程序?

一. 何为微信小程序? 1. 微信小程序是一种全新的连接用户与服务的方式 2. 它可以在微信内被便捷地获取和传播,同时具有出色的使用体验 二. 如何开发小程序 1. 开发小程序的第一步: 你需要拥有一个小程序帐号,通过这个帐号你就…

vue如何引入element-ui

2.x用element-ui 3.x用element-plus https://blog.csdn.net/weixin_41207479/article/details/127066333 引入element-ui的三种方式