其他分享
首页 > 其他分享> > CAN 通讯协议 学习笔记(1)

CAN 通讯协议 学习笔记(1)

作者:互联网

目录  CAN 通讯协议

 1.来源与定义

 2.物理构成

 3.总线逻辑

 4.帧的格式以及分类

 5.数据竞争机制

 6.检测机制

 

 

1.来源与定义

    CAN是控制器局域网络(Controller Area Network,CAN)上的物理层和链路层的协议。是由德国BOSCH公司开发,并最终成为

国际标准11898,是汽车计算机控制系统和嵌入式工业网络控制的 现场总线。

     CAN属于现场总线范畴,她是一种有效支持分布式控制或实时控制的串行通信网络。

     协议11898.1,2,3(其中1是controor,2是高速收发器,例如检测或控制汽车车速,3是低速收发器,例如控制雨刮器)

----------->引出疑问?

(1)什么是物理层和链路层?

           设备之间通讯需要遵循一定的规范,物理层从硬件的角度实现链路层的逻辑电平。开放式系统互联通讯参考模型(Open

system interconnection Reference Model,简称OSI),一种试图将各种计算机在世界范围内互联的标准框架。

                           

其中

         物理层:表现电气特性和机械特性,两根总线加总线两端连接120欧姆的电阻。

         数据链接层:表现帧的格式,传输大小,过滤的设置。

 

(1)什么是分布式控制?

             分布式控制就是总线空闲时间内上任意节点都可以竞争发送消息,没有所谓的主机和从机的概念。

(3)与其他通讯协议比较?

                                


2.物理构成

           CAN总线网络主要挂在CAN_H和CAN_L,各个节点通过两条线实现信号的串行差分传输,为了避免信号的反射和干扰,

还需要在CAN_H和CAN_L之间接上120Ω的终端电阻。为什么是120欧姆,因为其电缆的阻抗特性为120Ω。具体如下图所示。

                              

如果进一步将信号节点剖析,就会知道下面的信息

1.设备号 host   

2.控制器 controller

3.传送器transmitter ,控制  收发,高速、低速等

                                   


3.总线逻辑

 3.1显性和隐性

CAN总线上的数据位(又称CAN总线位数值)采用两种互补的逻辑值,即显性和隐性

3.2 差分电压

                                                         Vdiff =CAN_H - CAN_L

                                         

其中电位差Vdiff 决定其逻辑电平的显性和隐性。

3.3 CAN总线类型

CAN总线类型分别是 高速CAN、容错CAN(低速CAN)、单线CAN。

不同类型的CAN总线 电位差Vdiff对应的逻辑电平不同。

如果有电位差且CAN_H>CAN_L,为显性,即逻辑0

                 只有在 CAN_L<CAN_H  ,显性,即逻辑0

        

                       

4.帧的格式以及分类(别名又叫报文)

                                  

1)数据帧和扩展帧

数据帧包括  =  SOF(1bit显性) + 仲裁域(11bit_ID+1bit_RTR) + 控制域(12bit)+ data(8 byte) + CRC校验(15bit数据校验和1bit隐性位的界定值)

+相应ack(2bit)+EOF(7bit隐性)+ITM(帧间隔)其中ITM被用来判断节点是否过载,不属于数据帧的内容,先列出来。

------------------------------------------------------------------------------->流程

BUS idle

SOF(START OF FRAME)

1bit 显性位

仲裁域:

         数据帧的ID(标识符)就是节点的ID,只有接收方的过滤器没有屏蔽你的ID,你发送的消息才能被接收。同理作为接受方,你没有屏蔽对方的消息,你才能收到

数据帧。

         RTR是表示数据帧和远程帧。远程帧没有数据端date,是对方设备发送命令请求而已。

控制域

       IDE:标准帧还是扩展帧(11bit还是29bit)

      R1 过渡帧

      DLC:发送数据、接收数据的长度

数据域

      8byte

CRC

      CRC 校验位15bit数据校验和1bit隐性位界定符

EOF(end of frame)

7位 隐性位

ITM :帧间隔,实际不属于帧内的区域,必须等待帧间隔才能发送消息

正常是3bit 隐性位,如果出现过载帧就会导致出现显性位0

BUS IDLE

---------------------------------------------------------------------------------->结束

 

 

2.远程帧(RTR REMOTE TRANSMIT REQUEST)

                   

3.错误帧:就是传输中出现相关错误

     

4.过载帧:过载帧是接收节点向总线上其它节点报告自身接收能力达到极限的帧。

                      过载帧是接收节点向总线上其它节点报告自身接收能力达到极限的帧。我接收节点Node_A已经没有能力处理你们发来的报文了。

                 

对于过载帧的帧结构的理解:接收节点Node_A达到接收极限时,就会发送过载帧到总线上。显然过载标志的6个连续显性位会屏蔽掉总线上其他节点的发送。

也就是这个时候node_A通过发送过载帧的方式来破坏其他节点的发送,这样在Node_A发送过载帧期间,其他节点就不能成功发送报文,于是就相当于把其他节点

发送给她的报文推迟,也就是Node_A发送过载帧的这段时间得以“休息”。

 

有三种情况会引起过载帧:

 

 

未完待续

 

 

 

参考资料:

1.https://jingyan.baidu.com/article/46650658243a5ff548e5f873.html

2.野火STM32F10X零死角教程

3.https://blog.csdn.net/qq_40242571/article/details/118672112

4.https://blog.csdn.net/weixin_40528417/article/details/79871311(过载帧)

 

 

Date:2021-10-24   8:05:21 PM  in BingJiang library  

标签:协议,通讯,过载,总线,笔记,发送,隐性,节点,显性
来源: https://www.cnblogs.com/sophiaechoz/p/15455658.html