0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

CAN总线及相关寄存器配置分析

智能汽车电子与软件 来源:电控知识搬运工 作者:电控知识搬运工 2022-11-28 15:07 次阅读

嵌入式工程师一般都知道CAN总线广泛应用到汽车中,其实船舰电子设备通信也广泛使用CAN,随着国家对海防的越来越重视,对CAN的需求也会越来越大。

概述

CAN(Controller Area Network)即控制器局域网,是一种能够实现分布式实时控制的串行通信网络 想到CAN就要想到德国的Bosch公司,因为CAN就是这个公司开发的(和Intel)。 CAN有很多优秀的特点,使得它能够被广泛地应用。比如:传输速度最高到1Mbps,通信距离最远到10km,无损位仲裁机制,多主结构。 近些年来,CAN控制器价格越来越低,很多MCU也集成了CAN控制器。现在每一辆汽车上都装有CAN总线。 一个典型的CAN应用场景:9a9d9572-6e21-11ed-8abf-dac502259ad0.png

CAN总线标准

CAN总线标准只规定了物理层和数据链路层,需要用户自定义应用层。不同的CAN标准仅物理层不同。9ab19f0e-6e21-11ed-8abf-dac502259ad0.png  CAN收发器负责逻辑电平和物理信号之间的转换。9ac46a4e-6e21-11ed-8abf-dac502259ad0.png  将逻辑信号转换成物理信号(差分电平),或者将物理信号转换成逻辑电平。 CAN标准有两个,即IOS11898和IOS11519,两者差分电平特性不同。9ad67c3e-6e21-11ed-8abf-dac502259ad0.png高低电平幅度低,对应的传输速度快;9ae7a658-6e21-11ed-8abf-dac502259ad0.png*双绞线共模消除干扰,是因为电平同时变化,电压差不变。

物理层

CAN有三种接口器件:9af9e96c-6e21-11ed-8abf-dac502259ad0.png  9b09d94e-6e21-11ed-8abf-dac502259ad0.png多个节点连接,只要有一个为低电平,总线就为低电平,只有所有节点输出高电平时,才为高电平。所谓"线与"。 CAN总线有5个连续相同位后,就插入一个相反位,产生跳变沿,用于同步。从而消除累积误差。 和485、232一样,CAN的传输速度与距离成反比。9b198ad8-6e21-11ed-8abf-dac502259ad0.png  CAN总线,终端电阻的接法:9b2b252c-6e21-11ed-8abf-dac502259ad0.png  为什么是120Ω,因为电缆的特性阻抗为120Ω,为了模拟无限远的传输线。 数据链路层CAN总线传输的是CAN帧,CAN的通信帧分成五种,分别为数据帧、远程帧、错误帧、过载帧和帧间隔。 数据帧用来节点之间收发数据,是使用最多的帧类型;远程帧用来接收节点向发送节点接收数据;错误帧是某节点发现帧错误时用来向其他节点通知的帧;过载帧是接收节点用来向发送节点告知自身接收能力的帧;用于将数据帧、远程帧与前面帧隔离的帧。 数据帧根据仲裁段长度不同分为标准帧(2.0A)和扩展帧(2.0B) 帧起始9b3fc3ec-6e21-11ed-8abf-dac502259ad0.png帧起始由一个显性位(低电平)组成,发送节点发送帧起始,其他节点同步于帧起始; 帧结束由7个隐形位(高电平)组成。 仲裁段CAN总线是如何解决多点竞争的问题? 由仲裁段给出答案。 CAN总线控制器在发送数据的同时监控总线电平,如果电平不同,则停止发送并做其他处理。如果该位位于仲裁段,则退出总线竞争;如果位于其他段,则产生错误事件。9b50b67a-6e21-11ed-8abf-dac502259ad0.png  帧ID越小,优先级越高。由于数据帧的RTR位为显性电平,远程帧为隐性电平,所以帧格式和帧ID相同的情况下,数据帧优先于远程帧;由于标准帧的IDE位为显性电平,扩展帧的IDE位为隐形电平,对于前11位ID相同的标准帧和扩展帧,标准帧优先级比扩展帧高。 控制段共6位,标准帧的控制段由扩展帧标志位IDE、保留位r0和数据长度代码DLC组成;扩展帧控制段则由IDE、r1、r0和DLC组成。9b7f4512-6e21-11ed-8abf-dac502259ad0.png  数据段为0-8字节,短帧结构,实时性好,适合汽车和工控领域;9b9f78dc-6e21-11ed-8abf-dac502259ad0.png  CRC段CRC校验段由15位CRC值和CRC界定符组成。9bb1a930-6e21-11ed-8abf-dac502259ad0.pngACK段当接收节点接收到的帧起始到CRC段都没错误时,它将在ACK段发送一个显性电平,发送节点发送隐性电平,线与结果为显性电平。 远程帧远程帧分为6个段,也分为标准帧和扩展帧,且RTR位为1(隐性电平)9bc53bf8-6e21-11ed-8abf-dac502259ad0.pngCAN是可靠性很高的总线,但是它也有五种错误:
CRC错误:发送与接收的CRC值不同发生该错误;格式错误:帧格式不合法发生该错误;应答错误:发送节点在ACK阶段没有收到应答信息发生该错误;位发送错误:发送节点在发送信息时发现总线电平与发送电平不符发生该错误;位填充错误:通信线缆上违反通信规则时发生该错误。
当发生这五种错误之一时,发送节点或接受节点将发送错误帧。 为防止某些节点自身出错而一直发送错误帧,干扰其他节点通信,CAN协议规定了节点的3种状态及行为。9bd2f1e4-6e21-11ed-8abf-dac502259ad0.png  过载帧当某节点没有做好接收的"准备"时,将发送过载帧,以通知发送节点。9be705e4-6e21-11ed-8abf-dac502259ad0.png  帧间隔用来隔离数据帧、远程帧与他们前面的帧,错误帧和过载帧前面不加帧间隔。9c03f136-6e21-11ed-8abf-dac502259ad0.png构建CAN节点构建节点,实现相应控制,由底向上分为四个部分:CAN节点电路、CAN控制器驱动、CAN应用层协议、CAN节点应用程序。 虽然不同节点完成的功能不同,但是都有相同的硬件和软件结构。9c185ebe-6e21-11ed-8abf-dac502259ad0.png  CAN收发器和控制器分别对应CAN的物理层和数据链路层,完成CAN报文的收发;功能电路,完成特定的功能,如信号采集或控制外设等;主控制器与应用软件按照CAN报文格式解析报文,完成相应控制。 CAN硬件驱动是运行在主控制器(如P89V51)上的程序,它主要完成以下工作:基于寄存器的操作,初始化CAN控制器、发送CAN报文、接收CAN报文; 如果直接使用CAN硬件驱动,当更换控制器时,需要修改上层应用程序,移植性差。在应用层和硬件驱动层加入虚拟驱动层,能够屏蔽不同CAN控制器的差异。 一个CAN节点除了完成通信的功能,还包括一些特定的硬件功能电路,功能电路驱动向下直接控制功能电路,向上为应用层提供控制功能电路函数接口。特定功能包括信号采集、人机显示等。9c2941a2-6e21-11ed-8abf-dac502259ad0.png  CAN收发器是实现CAN控制器逻辑电平与CAN总线上差分电平的互换。实现CAN收发器的方案有两种,一是使用CAN收发IC(需要加电源隔离和电气隔离),另一种是使用CAN隔离收发模块。推荐使用第二种。 CAN控制器是CAN的核心元件,它实现了CAN协议中数据链路层的全部功能,能够自动完成CAN协议的解析。CAN控制器一般有两种,一种是控制器IC(SJA1000),另一种是集成CAN控制器的MCU(LPC11C00)。 MCU负责实现对功能电路和CAN控制器的控制:在节点启动时,初始化CAN控制器参数;通过CAN控制器读取和发送CAN帧;在CAN控制器发生中断时,处理CAN控制器的中断异常;根据接收到的数据输出控制信号;9c3cfcc4-6e21-11ed-8abf-dac502259ad0.png  接口管理逻辑:解释MCU指令,寻址CAN控制器中的各功能模块的寄存器单元,向主控制器提供中断信息和状态信息。 发送缓冲区和接收缓冲区能够存储CAN总线网络上的完整信息。 验收滤波是将存储的验证码与CAN报文识别码进行比较,跟验证码匹配的CAN帧才会存储到接收缓冲区。 CAN内核实现了数据链路的全部协议。

CAN协议应用层概述

CAN总线只提供可靠的传输服务,所以节点接收报文时,要通过应用层协议来判断是谁发来的数据、数据代表了什么含义。常见的CAN应用层协议有:CANOpen、DeviceNet、J1939、iCAN等。 CAN应用层协议驱动是运行在主控制器(如P89V51)上的程序,它按照应用层协议来对CAN报文进行定义、完成CAN报文的解析与拼装。例如,我们将帧ID用来表示节点地址,当接收到的帧ID与自身节点ID不通过时,就直接丢弃,否则交给上层处理;发送时,将帧ID设置为接收节点的地址。 CAN收发器SJA1000的输出模式有很多,使用最多的是正常输出模式,输入模式通常不选择比较器模式,可以增大通信距离,并且减少休眠下的电流9c55162e-6e21-11ed-8abf-dac502259ad0.png  收发器按照通信速度分为高速CAN收发器和容错CAN收发器。 同一网络中要使用相同的CAN收发器。 CAN连接线上会有很多干扰信号,需要在硬件上添加滤波器和抗干扰电路:9c67c062-6e21-11ed-8abf-dac502259ad0.png  也可以使用CAN隔离收发器(集成滤波器和抗干扰电路)。9c819762-6e21-11ed-8abf-dac502259ad0.png  9c91141c-6e21-11ed-8abf-dac502259ad0.png  CAN控制器与MCU的连接方式:9ca31d1a-6e21-11ed-8abf-dac502259ad0.pngSJA1000可被视为外扩RAM,地址宽度8位,最多支持256个寄存器9cb4e108-6e21-11ed-8abf-dac502259ad0.png9cc8c0ce-6e21-11ed-8abf-dac502259ad0.png  

														#defineREG_BASE_ADDR0xA000//寄存器基址  unsignedchar*SJA_CS_Point=(unsignedchar*)REG_BASE_ADDR;  //写SJA1000寄存器 voidWriteSJAReg(unsignedcharRegAddr,unsignedcharValue) { *(SJA_CS_Point+RegAddr)=Value; return; }  //读SJA1000寄存器 unsignedcharReadSJAReg(unsignedcharRegAddr) { return(*(SJA_CS_Point+RegAddr)); }
															9cdbdca4-6e21-11ed-8abf-dac502259ad0.png
															 9cf12550-6e21-11ed-8abf-dac502259ad0.png
															 将缓存区的数据连续写入寄存器:

														…… for(i=0;i
															将连续多个寄存器连续读入缓存区:

														…… for(i=0;i
															9d00aa0c-6e21-11ed-8abf-dac502259ad0.png
															 头文件包含方案:1. 每个程序包含用到的头文件2. 每个程序包含一个公用头文件,公用头文件包含所有其他头文件

														#ifndef__CONFIG_H__//防止头文件被重复包含 #define__CONFIG_H__ #include<8051.h>//包含80C51寄存器定义头文件 #include"SJA1000REG.h"//包含SJA1000寄存器定义头文件 //定义取字节运算 #defineLOW_BYTE(x)(unsignedchar)(x) #defineHIGH_BYTE(x)(unsignedchar)((unsignedint)(x)>>8) //定义振荡器时钟处理器时钟频率(用户可以根据实际情况作出调整) #defineOSCCLK11059200UL //宏定义MCU的时钟频率 #defineCPUCLK(OSCCLK/12) #endif//__CONFIG_H__
															SJA1000上电后处于复位状态,必须初始化后才能工作:(1)置位模式寄存器Bit0位进入复位模式;(2)设置时钟分频寄存器选择时钟频率、CAN模式;(3)设置验收滤波,设定验证码和屏蔽码;(4)设置总线定时器寄存器0、1设定CAN波特率;(5)设置输出模式;(6)清零模式寄存器Bit0位退出复位模式;
															模式寄存器9d173b28-6e21-11ed-8abf-dac502259ad0.png
															 检测模式:SJA1000发送CAN帧时不检查应答位;
															只听模式:此模式下SJA1000不会发送错误帧,用于自动检测波特率;SJA1000以不同的波特率接收CAN帧,当收到CAN帧时,表明当前波特率与总线波特率相同。
															波特率设置CAN总线无时钟,使用异步串行传输;波特率是1秒发送的数据位;9d314e14-6e21-11ed-8abf-dac502259ad0.png
															 CAN帧发送:发送CAN帧的步骤:1.检测状态寄存器,等待发送缓冲区可用;2.填充报文到发送缓冲区;3.启动发送。9d48bf22-6e21-11ed-8abf-dac502259ad0.png
															 SJA1000具有一个12字节的缓冲区,要发送的报文可以通过寄存器16-28写入,也可通过寄存器96-108写入或读出:9d5c0aa0-6e21-11ed-8abf-dac502259ad0.png9d70529e-6e21-11ed-8abf-dac502259ad0.png设置发送模式:

														charSetSJASendCmd(unsignedcharcmd) { unsignedcharret; switch(cmd) { default: case0: ret=SetBitMask(REG_CAN_CMR,TR_BIT);//正常发送 break; case1: ret=SetBitMask(REG_CAN_CMR,TR_BIT|AT_BIT);//单次发送 break; case2: ret=SetBitMask(REG_CAN_CMR,TR_BIT|SRR_BIT);//自收自发 break; case0xff: ret=SetBitMask(REG_CAN_CMR,AT_BIT);//终止发送 break; } returnret; }
															发送函数: 

														unsignedcharSJA_CAN_Filter[8]= { //定义验收滤波器的参数,接收所有帧 0x00,0x00,0x00,0x00, //ACR0~ACR3 0xff,0xff,0xff,0xff //AMR0~AMR3 };  unsignedcharSTD_SEND_BUFFER[11]= { //CAN发送报文缓冲区 0x08,//帧信息,标准数据帧,数据长度=8 0xEA,0x60,//帧ID=0x753 0x55,0x55,0x55,0x55,0xaa,0xaa,0xaa,0xaa//帧数据 };  voidmain(void)//主函数,程序入口 { timerInit();//初始化 D1=0; SJA1000_RST=1;//硬件复位SJA1000 timerDelay(50);//延时500ms SJA1000_RST=0; SJA1000_Init(0x00,0x14,SJA_CAN_Filter);//初始化SJA1000,设置波特率为1Mbps //无限循环,main()函数不允许返回 for(;;) { SJASendData(STD_SEND_BUFFER,0x0); timerDelay(100);//延时1000ms } }
															为什么帧ID是0x753,这与CAN帧在缓冲区的存储格式有关。9d8c93dc-6e21-11ed-8abf-dac502259ad0.png
															 9d9d4150-6e21-11ed-8abf-dac502259ad0.png
															 终端电阻非常重要,当波特率较高而且没加终端电阻时,信号过冲非常严重。9db41a42-6e21-11ed-8abf-dac502259ad0.pngSJA1000有64个字节的接收缓冲区(FIFO),这可以降低对MCU的要求。MCU可以通过查询或中断的方式确定SJA1000接收到报文后读取报文。审核编辑:郭婷

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 控制器
    +关注

    关注

    112

    文章

    15239

    浏览量

    171224
  • CAN总线
    +关注

    关注

    145

    文章

    1812

    浏览量

    129600
  • 寄存器
    +关注

    关注

    30

    文章

    5037

    浏览量

    117763

原文标题:详解CAN 总线及其相关寄存器配置

文章出处:【微信号:智能汽车电子与软件,微信公众号:智能汽车电子与软件】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    需使STM32F103C8T6的PB1输出为高电平,请问相关的模式寄存器和输出寄存器该如何配置

    需使STM32F103C8T6的PB1输出为高电平,请问相关的模式寄存器和输出寄存器该如何配置,并写出分析过程
    发表于 03-27 07:51

    如何根据自己设计中的寄存器配置总线定义来生成一套寄存器配置模版

    无论是FPGA还是ASIC,系统设计中总会存在配置寄存器总线的使用,我们会将各种功能、调试寄存器挂载在寄存器
    的头像 发表于 03-04 13:56 402次阅读
    如何根据自己设计中的<b class='flag-5'>寄存器</b><b class='flag-5'>配置</b><b class='flag-5'>总线</b>定义来生成一套<b class='flag-5'>寄存器</b><b class='flag-5'>配置</b>模版

    求助,如何清除RSTSTAT寄存器的所有位?

    我得清除 TC322LP 中的 RSTSTAT 寄存器。 冷 PORST 和待机相关寄存器 CAN RSTCON2清除。CLR 位。 但是我如何 C
    发表于 01-26 08:19

    NUC970怎样配置CAN寄存器,使CAN通信能够接收任意ID的数据包?

    NUC970怎样配置CAN寄存器,使CAN通信能够接收任意ID的数据包?
    发表于 01-17 08:04

    ADXL357测量温度和加速度,需要配置哪些寄存器配置寄存器的值为多少?

    ADXL357测量温度和加速度,需要配置哪些寄存器配置寄存器的值为多少
    发表于 12-29 06:23

    使用FPGA通过SPI总线控制AD9266寄存器,可以回读寄存器默认值,但是无法改变寄存器值怎么解决?

    使用FPGA通过SPI总线控制AD9266寄存器,可以回读寄存器默认值,但是无法改变寄存器值。 不知道有没有人遇到过同样的问题。 程序是自己写的,公司电脑不让联网,所以没有代码贴出
    发表于 12-13 08:29

    AD9162通过SPI进行寄存器配置时,只需要配置sequence中的寄存器吗?

    对AD9162通过SPI进行寄存器配置时,只需要配置sequence中的寄存器吗?sequence外的其它寄存器就不用管了? sequen
    发表于 12-11 06:36

    RA2快速设计指南 [6] 寄存器写保护和I/O端口配置

    RA2快速设计指南 [6] 寄存器写保护和I/O端口配置
    的头像 发表于 10-24 16:48 353次阅读
    RA2快速设计指南 [6] <b class='flag-5'>寄存器</b>写保护和I/O端口<b class='flag-5'>配置</b>

    CAN总线关闭故障的诊断流程

    汽车CAN总线关闭故障发生时,应分析物理层包括CAN线路、CAN控制器及收发器、CAN信号干扰等
    发表于 10-16 15:36 822次阅读
    <b class='flag-5'>CAN</b><b class='flag-5'>总线</b>关闭故障的诊断流程

    STM32 CAN接收/发送错误寄存器如何清零?

    STM32 CAN接收/发送错误寄存器如何清零?  CAN总线是一种常用的串行总线,其具有高可靠性、高速率、容错能力强等特点,广泛应用于汽车
    的头像 发表于 09-14 14:22 2818次阅读

    NUC970怎样配置CAN寄存器,使CAN通信能够接收任意ID的数据包?

    1、NUC970 裸机程序2、怎样配置CAN寄存器,使CAN通信能够接收任意ID的数据包。 谢谢!
    发表于 09-04 06:11

    寄存器是什么?怎么操作寄存器点亮LED灯?

    寄存器,是集成电路中非常重要的一种存储单元,通常由触发器组成。在集成电路设计中,寄存器可分为电路内部使用的寄存器和充当内外部接口的寄存器这两类。
    的头像 发表于 07-21 16:59 2982次阅读
    <b class='flag-5'>寄存器</b>是什么?怎么操作<b class='flag-5'>寄存器</b>点亮LED灯?

    基于DWC2的USB驱动开发-发送相关寄存器DMA寄存器详解

    本文转自公众号,欢迎关注 基于DWC2的USB驱动开发-发送相关寄存器DMA寄存器详解 (qq.com) 前言 如下寄存器DIEPxxx,对应IN端点,和发送数据
    的头像 发表于 07-16 16:42 888次阅读
    基于DWC2的USB驱动开发-发送<b class='flag-5'>相关</b>的<b class='flag-5'>寄存器</b>DMA<b class='flag-5'>寄存器</b>详解

    配置芯片寄存器的SPI通信协议的verilog实现

    最近正在调试一个芯片的评估板,其中配置寄存器使用的是SPI通信协议。其实很多芯片寄存器配置都用到了SPI通信协议,我们今天就需要实现这个SPI通信协议。
    的头像 发表于 06-16 09:50 1292次阅读
    <b class='flag-5'>配置</b>芯片<b class='flag-5'>寄存器</b>的SPI通信协议的verilog实现

    如何同步S32K118的can总线

    如何同步S32K118的can总线?我使用 can_pal_s32k118 的示例,但 ESR1 寄存器 指示 Flexcan 未同步到 CAN
    发表于 05-24 10:12