1.通信机制

  • 发送报文。 1.首先检测Bus状态,空闲 则发送 报文且回读

        2.线与机制,若有两个节点同时发报文

         报文结构:

         通过ID进行仲裁(规则判定),若ID值小则0位越展示在前面。如:

         0001 比1000 小 则0001中  显性位将1000覆盖    

题目:如有如下节点发送报文,看ID

A:5          5

B:   7

C:    3    3

D:      6        6

发送流程:5先发出,下一步是7和3,由于3小则3先发出;

     后续则是6和7,6小则6先发  按照此逻辑总线的报文内容依次:5363567

例2:

A:2   1

B:1  

C:3

BUS:A节点先进入,按照ID小的原则排序 应该是 123 但由于A节点先进入到寄存器,所以2先发

2131

  • 报文的接收  节点只会接收和自己相关性的内容,由报文ID控制。相同ID则接收 不相同的则过滤。编码采用NRZ编码,不适用曼彻斯特编码

   NRZ编码:可以使报文紧凑。0是低  1是高  (0是显性位  2v)

曼彻斯特编码:0是上升沿  1是下降沿  。优点:可以位同步,定时更准确

     如:0110

NRZ与位填充:

  NRZ编码沿比较少  则定时不精准,需要用位填充来补短板

CAN总线需要 发连续5个相同位 补一个极性相反位

收连续5个相同位  去 一个极性相反位

2.CAN帧类型

  数据帧【重点】分为 标准帧 和 扩展帧

标准帧:

  远程帧:

SOF(Start of Frame,帧起始)

SOF是数据帧传输的起始位。发送方(sender)会发送一个显性电平作为SOF,由于总线空闲时总线会保持隐性电平,因此SOF发出后会产生一个跳变沿用于整个CAN网络的时间同步。为了在帧传输期间保持与发送方的同步,接收方会在所有隐性电平到显性电平的跳变沿进行是否与发送方保持同步的判断。如果出现偏差,接收方将按照相关相位误差量重新进行同步(重同步)。

ID和RTR(Remote Transmission Request,远程传输请求位)

SOF之后是标识符(ID),用于区分数据帧的优先级,并根据通信矩阵中定义的收发关系为节点中的接收过滤器提供过滤依据。ID之后是RTR位。发送方将其用于通知接收方帧的类型(数据帧或远程帧)。RTR位为显性表示数据帧,隐性则表示远程帧

IDE(Identifier Extension bit,标识符扩展位)

IDE位用于区分标准格式和扩展格式。标准ID有11位,扩展ID有29位,“

ide是1 扩展帧     0是标准帧

DLC(Data Length Code,数据长度代码)

DLC表示数据场中的有效负载的字节数。一个数据帧最多可以传输八个字节。

表示9-15则用8表示

CRC(cyclic redundancy check,循环冗余校验码)和ACK(acknowledge,应答)

校验场使用以界定符(delimiter)为结尾的CRC来保护有效负载。接收方在ACK位做出肯定或否定的应答,ACK位后同样有一位界定符。

CRC   DEL    ACK     ACKDEL    EOF      ITM

15位    1       1              1            7           3

DEL、ACKDEL、EOF、ITM隐性位 固定是1

ACK  对是0  错是1

节点发送 以及节点接收 都会计算CRC 并对比值 

远程帧:无数据 只有ID

错误帧【重点】:

位错误:回读位与发出位不同【发送node可以检测出来】

填充错误:【发送和接收节点都可以检测出来】

ACK错误:发送节点可以检测出来

格式错误:【发送和接收节点都可以检测出来】CRC之后错误

CRC错误:接收节点可以探测到错误

被动错误转化为主动错误:则 REC<128 or TEC<128

主动错误帧:

  错误标志:6个连续的显性位  0-6个错误标志叠加  8个错误界定符

被动错误帧:

  错误标志:6个连续的隐性位  0或6个错误标志叠加  8个错误界定符

超载帧

帧空间

3.错误检测与处理【重点】

4.位定时与同步

  硬同步

  重同步

5.CAN控制器(不讲)

CAN总线数据链路层(一)的更多相关文章

  1. 探讨CAN总线的抗干扰能力

    探讨CAN总线的抗干扰能力 CAN总线经近20年的发展已步入壮年期,它不仅在汽车领域的应用占据一定优势,在其他工业应用上也生机勃勃.枝繁叶茂.究竟是什么原因使它这么成功?当人们发现它的局限性,又面临新 ...

  2. PCIe扫盲——一个Memory Read操作的例子

    连载目录篇:http://blog.chinaaet.com/justlxy/p/5100053251 前面的一系列文章简要地介绍了PCIe总线的结构.事务层.数据链路层和物理层.下面我们用一个简单地 ...

  3. CAN总线(一)

    原文出处:http://www.cnblogs.com/jacklu/p/4729638.html 嵌入式的工程师一般都知道CAN总线广泛应用到汽车中,其实船舰电子设备通信也广泛使用CAN,随着国家对 ...

  4. TCP/IP详解学习笔记(2)-- 数据链路层

    1.概述      数据链路层属于计算机网络的底层,使用的信道主要有点对点信道和广播信道两种类型.      在TCP/IP协议族中,数据链路层主要有三个目的:           1)为IP模块发送 ...

  5. Beaglebone Back学习六(Can总线测试)

    Can总线测试 1 Can总线 控制器局域网 (Controller Area Network, 简称 CAN 或 CANbus)是一种通信协议,其特点是允许网络上的设备直接互相通信,网络上不需要主机 ...

  6. 【单片机通信协议】CAN总线基础知识

    CAN总线基础知识(一) 1.1 CAN总线是什么? CAN(Controller Area Network)是ISO国际标准化的串行通信协议.广泛应用于汽车.船舶等.具有已经被大家认可的高性能和可靠 ...

  7. CAN总线

    1.CAN(controller area network) LAN(local area network)局域网 2.CAN等通信协议的开发,使多种LAN通过网关进行数据交换得以实现.如应用在汽车电 ...

  8. CAN总线与RS485的比较

    CAN总线与RS485的比较 http://blog.csdn.net/reille/article/details/6135546 can总线与485总线有什么区别?  http://blog.16 ...

  9. stm32之CAN总线基础

    can总线协议概述: CAN是Controller Area Network的缩写,由德国博世公司开发:CAN通过ISO11891以及ISO11519进行了标准化:     CAN总线的特点: 1.多 ...

  10. CAN总线基础

    can总线协议: 涵盖了OSI规定的传输层.数据链路层.物理层 物理层: 决定了位编码方式(NRZ编码,6个位插入填充位),位时序(位时序.位的采样).同步方式(根据同步段ss实现同步,并具有再同步功 ...

随机推荐

  1. 【设计模式】Java设计模式 - 组合模式

    Java设计模式 - 组合模式 不断学习才是王道 继续踏上学习之路,学之分享笔记 总有一天我也能像各位大佬一样 原创作品,更多关注我CSDN: 一个有梦有戏的人 准备将博客园.CSDN一起记录分享自己 ...

  2. C++ 指针与二维数组名

    和一维数组类似,C++ 将二维数组名解释为其第一个元素的地址,而二维数组的第一个元素为一维数组,以下面的程序为例,二维数组名 array2d 和 &array2d[0] 等效,它们的类型都为 ...

  3. 004-GoingDeeperConvolutions2014(googLeNet)

    Going Deeper with Convolutions #paper 1. paper-info 1.1 Metadata Author:: [[Christian Szegedy]], [[W ...

  4. 创建一个 autocomplete 输入系统 - 前端 + 后端

    文章转载自:https://mp.weixin.qq.com/s/uqchdrkhdFsof0ZFtECujg 我们经常在网站搜索输入时,会帮我们提醒自动完成的功能,比如: 图片 当我们在百度上搜索 ...

  5. 分布式安装部署MinIO

    官方文档地址:http://docs.minio.org.cn/docs/master/distributed-minio-quickstart-guide 前提条件:分布式Minio至少需要4个硬盘 ...

  6. 如何在 Docker 之上使用 Elastic Stack 和 Kafka 可视化公共交通

    文章转载自:https://blog.csdn.net/UbuntuTouch/article/details/106498568 需要掌握的知识点: 1.使用docker-compose方式部署一套 ...

  7. 在客户端电脑使用 kubectl 远程管理 Kubernetes

    日常工作中,可能需要在自己的笔记本电脑上执行 kubectl 命令以管理远程 Linux 服务器上的 Kubernetes 集群.通过调用 kubernetes API 来实现对 Kubernetes ...

  8. httpd常用配置之虚拟主机

    httpd常用配置 目录 httpd常用配置 虚拟主机: 相同IP不同端口 不同IP相同端口 相同IP相同端口不同域名 切换使用MPM(编辑/etc/httpd/conf.modules.d/00-m ...

  9. 什么是Scrum?Scrum的核心要点和精髓

    有点长,期望你能通过本文彻底了解 Scrum. 上一篇文章<研发效能组织能力建设之特性团队FeatureTeam(上)>,我们介绍了一个非常有意思且高效的组织模式-特性团队.我们首先介绍了 ...

  10. Magnet: Push-based Shuffle Service for Large-scale Data Processing

    本文是阅读 LinkedIn 公司2020年发表的论文 Magnet: Push-based Shuffle Service for Large-scale Data Processing 一点笔记. ...