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

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

3天内不再提示

CAN总线通信系统的研究与设计

电子设计 来源:郭婷 作者:电子设计 2019-01-09 08:23 次阅读

0 引 言

众所周知,虽然目前8位单片机正逐渐被速度高,性能强的16位或32位微处理器所取代,但8位单片机仍以其低廉的价格、丰富的外围芯片以及众多的多功能产品而在低端应用市场占据主流地位。数字信号处理器(Digital Signal ProcessorDSP)作为一种具有高速数字信号处理能力的新型单片机,在通信、自动控制、航天航空、军事、医疗等领域广泛应用。在比较复杂的测控系统中,如微机电动机保护装置,要求在毫秒级的短时间内对电动机实现实时保护和测量,所以对装置硬件系统的实时数据处理能力要求较高,而传统的基于单 CPU微处理器的方案己经难以胜任。因此,这里采用数字信号处理器与单片机构成的双CPU结构。由数字信号处理器完成多通道A/D转换、各种判据算法的运算等功能,而单片机作为整个装置的控制单元,主要负责实时时钟控制、参数管理、人机接口及串并行通信接口的控制等。这种双CPU结构充分发挥数字信号处理器与单片机各自的功能特点。其中,双CPU系统之间的数据通信可采用双口RAM、串行通信等方式,但这两种方式存在只能实现点对点通信,通信速度慢,可靠性差等缺点,不利于系统扩展。因而研究通信速度快,可靠性高,实时性强的CAN总线通信系统具有重要意义。

1 CAN总线介绍

控制器局域网络(Controller Area Network,CAN)是一种串行多主站控制器局域网总线。它具有很高的网络安全性、通信可靠性和实时性,而且简单实用,网络成本低,特别适用于环境温度恶劣、电磁辐射强和振动大的工业环境。CAN总线可有效支持分布式控制或实时控制。该总线的通信介质可以是双绞线、同轴电缆或光纤。其主要特点如下:

(1)CAN总线为多主站总线,各节点可在任意时刻向网络上的其他节点发送信息,且不分主从;

(2)CAN总线采用独特的非破坏性总线仲裁技术,高优先级节点优先传送数据,故实时性好;

(3)CAN总线具有点对点、一点对多点及全局广播传送数据的功能;

(4)CAN总线采用短帧结构,每帧有效字节数最多为8个,数据传输时间短,并有CRC及其他校验措施,数据出错率极低;

(5)CAN总线上某一节点出现严重错误时,可自动脱离总线,而总线上的其他操作不受影响;

(6)CAN总线系统扩充时,可直接将新节点挂在总线上,因而走线少,系统扩充容易,改型灵活;

(7)CAN总线的最大传输速率可达1 Mb/s,直接通信距离最远可达10 km(速率在5 Kb/s以下);

(8)CAN总线上的节点数取决于总线驱动电路,在标准帧(11位报文标识符)时,可达到110个,而在扩展帧(29位报文标识符)时,个数不受限。

2 单片机与数字信号处理器CAN通信系统接口电路设计

单片机与数字信号处理器种类较多,在研究其通信系统时,以广泛使用的MCS-51单片机以及适于运动控制的美国德州仪器(TI)公司TMS320LF2407为例进行研究。

2.1 单片机通信系统接口电路设计

MCS-51单片机组成CAN通信系统需要扩展CAN控制器,本系统采用的CAN控制器是SJA1000。SJA1000是PHILIPS公司生产的既支持CAN 2.0B,又支持CAN 2.0A的CAN控制器。与SJA1000配套使用的CAN总线驱动器是PCA82C250,它是PHILIPS推出的CAN控制器和物理总线接口芯片,可提供对总线的差分发送和接收。CAN模块总线控制器、总线驱动器连接基本方法如图1所示。为增强CAN总线节点的抗干扰能力,SJA1000通过高速光耦6N137后与PCA82C250相连,这样就能很好地实现本系统与CAN总线的电气隔离。电源的隔离采用小功率电源隔离模块。这些部分虽然增加了接口电路的复杂性,但是却提高了系统的稳定性和安全性。

CAN总线通信系统的研究与设计

TMS320LF2407内部集成一个完全的CAN控制器,但CAN控制器必须通过CAN驱动芯片才能与其他CAN控制器进行通信,这里采用 PCA82C250。因为TMS320LF2407用3.3 V供电,而PCA82C250用5 V供电。TMS320LF2407通过高速光耦6N137后与82C250相连,不仅增强了CAN总线节点的抗干扰能力,而且实现了电平转换。

3 数字信号处理器与单片机通信系统软件设计

数字信号处理器与单片机组成的CAN总线通信系统进行数据通信时,应约定通信协议,如帧格式、波特率、标识符等。各节点软件设计均包括数据发送和接收子程序以及CAN总线控制器初始化子程序。这里着重研究CAN总线控制器的初始化。

CAN总线通信系统的研究与设计

3.1 单片机通信系统软件设计

单片机CAN通信系统软件设计主要是指SJA1000总线控制器的初始化程序设计。

CAN总线控制器初始化程序主要是通过对SJA1000寄存器写入相应的控制字,从而确定SJA1000的工作方式。SJA1000需要初始化的寄存器有:模式寄存器MODE、时钟分频寄存器CDR、接收代码寄存器ACR、接收屏蔽寄存器AMR、中断使能寄存器IER、总线定时寄存器BTR、输出控制寄存器OCR等。其中,总线定时寄存器BTR的值决定CAN通信波特率,而波特率正确与否,是数字信号处理器与单片机实现CAN通信的关键。因为这些寄存器仅能在SJA1000复位期间进行写访问,因此在对这些寄存器初始化之前,必须确保系统进入复位状态,在初始化后,须清除复位请求位,使SJA1000返回正常运行状态,其初始化子程序如下:

CAN总线通信系统的研究与设计

CAN总线通信系统的研究与设计

3.2 数字信号处理器通信系统软件设计

在使用数字信号处理器CAN控制器前必须对它的一些内部寄存器进行设置,如对位定时器的设置及对邮箱进行初始化。位定时器主要由CANBCR1和CANBCR2两个寄存器组成,配置对位定时器也就是设置这两个寄存器,其值决定了CcAN控制器的通信波特率、同步跳转宽度、采样次数和重同步方式等。对邮箱初始化主要是对邮箱进行配置,设置邮箱的标识符以及接收滤波器的设置等。 CAN控制器初始化子程序如下:

CAN总线通信系统的研究与设计

CAN总线通信系统的研究与设计

4 结 语

单片机与数字信号处理器CAN总线通信系统实验过程中,发送端采用查询方式,接收端采用中断方式,利用键盘改变发送数据,接收端利用液晶显示器实时显示接收数据。反复试验表明,该系统工作稳定性较高;该系统硬件电路或软件程序稍加改动可用于单片机与数字信号处理器或数字信号处理器与数字信号处理器等双 CPU或多CPU测控系统中,且应用前景广阔。

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

    关注

    5999

    文章

    43968

    浏览量

    620745
  • CAN总线
    +关注

    关注

    145

    文章

    1811

    浏览量

    129584
  • 信号处理器
    +关注

    关注

    1

    文章

    239

    浏览量

    25026
收藏 人收藏

    评论

    相关推荐

    什么是CAN总线通信CAN总线工作原理

    这意味着变送器通过CAN收发器改变总线电平,并将其信息传输到CAN总线。接收器通过监测总线电平将总线
    发表于 02-19 14:53 1294次阅读
    什么是<b class='flag-5'>CAN</b><b class='flag-5'>总线</b><b class='flag-5'>通信</b>?<b class='flag-5'>CAN</b><b class='flag-5'>总线</b>工作原理

    CAN总线共模电感选型

    CAN总线共模电感的定义和作用 CAN总线共模电感是一种用于CAN总线
    的头像 发表于 01-05 13:42 1102次阅读

    can总线传输距离

    can总线传输距离  CAN总线是一种串行通信协议,常用于汽车行业中的数据通信。它被广泛应用于车
    的头像 发表于 12-07 18:09 1618次阅读

    一种车用CAN总线网络测试系统研究

    电子发烧友网站提供《一种车用CAN总线网络测试系统研究.pdf》资料免费下载
    发表于 10-13 11:35 0次下载
    一种车用<b class='flag-5'>CAN</b><b class='flag-5'>总线</b>网络测试<b class='flag-5'>系统</b>的<b class='flag-5'>研究</b>

    汽车前照灯CAN总线多路传输系统研究与设计

    电子发烧友网站提供《汽车前照灯CAN总线多路传输系统研究与设计.pdf》资料免费下载
    发表于 10-08 14:30 0次下载
    汽车前照灯<b class='flag-5'>CAN</b><b class='flag-5'>总线</b>多路传输<b class='flag-5'>系统</b>的<b class='flag-5'>研究</b>与设计

    基于CAN总线的温度测控系统介绍

    ,不会出现网络瘫痪,从而提高整个系统的稳定性。cAN协议采用CRc检验并可提供相应的错误处理功能,保证了数据通信的可靠性。同时,由于cAN总线
    发表于 09-19 06:45

    can总线为什么要用双绞线?can总线不用双绞线可以吗?

    can总线为什么要用双绞线?can总线不用双绞线可以吗? CAN总线是一种数据
    的头像 发表于 09-14 16:48 4016次阅读

    can总线负载率多少合理

    不同设备之间进行交流。CAN总线的负载率是指在给定时间内,CAN总线所采用的通信参数与总线容量之
    的头像 发表于 09-07 15:05 2517次阅读

    can总线通信协议有哪些 CAN接口保护及工作原理

    CAN总线(Controller Area Network)是一种广泛应用于汽车、工业自动化和其他领域的串行通信协议。以下是几种常见的CAN总线
    的头像 发表于 08-18 14:40 1.2w次阅读
    <b class='flag-5'>can</b><b class='flag-5'>总线</b>的<b class='flag-5'>通信</b>协议有哪些 <b class='flag-5'>CAN</b>接口保护及工作原理

    CAN总线通信协议是什么

    ,各种各样的电子控制系统被开发了出来。由于这些系统之间通信所用的数据类型及对可靠性的要求不尽相同,由多条总线构成的情况很多,线束的数量也随之增加。 总结下,当一个节点要向其它节点发送数
    的头像 发表于 07-18 11:10 2911次阅读
    <b class='flag-5'>CAN</b><b class='flag-5'>总线</b><b class='flag-5'>通信</b>协议是什么

    一文浅析CAN-FD总线通信应用

    传统的车载CAN总线最高支持500 kbit/s的传输速率,每帧只能承载8 bytes的数据,由于传输速率和数据长度的限制,在自动驾驶和智能网联对网络通信的高要求背景下,使用传统 CAN
    发表于 06-18 17:14 2232次阅读
    一文浅析<b class='flag-5'>CAN</b>-FD<b class='flag-5'>总线</b><b class='flag-5'>通信</b>应用

    基于FPGA的CAN总线通信节点设计

    点击上方 蓝字 关注我们 摘要:以FPGA 代替传统的单片机和外围扩展芯片, 给出了CAN 总线通信节点的详细设计方案。其中以SJA1000为CAN
    的头像 发表于 06-18 11:15 1982次阅读

    CAN总线通信协议的基础知识

    本文将介绍CAN总线通信协议的基础知识,目前的内容仅为通用的协议部分,暂不涉及具体的外设模块的用法。研究通信协议的具体内容,主要是看建立
    的头像 发表于 06-16 10:58 4766次阅读
    <b class='flag-5'>CAN</b><b class='flag-5'>总线</b><b class='flag-5'>通信</b>协议的基础知识

    CAN 总线错误检测机制#can总线

    CAN 总线
    北汇信息POLELINK
    发布于 :2023年05月26日 13:54:03