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

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

3天内不再提示

基于AT91SAM7A3芯片和CAN收发器实现CAN/LIN网关的设计

电子设计 来源:单片机与嵌入式系统应用 作者:牟文强,施国梁 2021-04-12 11:28 次阅读

随着汽车电子技术的发展,CAN、LIN总线在汽车网络中得到越来越广泛的应用。同时,实现不同性质、不同速率之间的网络通信也成为必须要解决的问题。本文提出一种高速CAN/低速CAN/LIN网关的设计方案,详细介绍了CAN、LIN节点电路的设计以及数据的传输处理过程。

随着汽车电子的发展,传统的点对点的通信已经不能满足现代汽车通信的要求。汽车电子网络技术正成为实现汽车控制系统的首选,它使汽车电子技术进入一个全新的时代。

20世纪90年代,美国汽车工程师协会SAE(Society of Automotive Engineers)将汽车数据传输网分成了A、B、C三类:A类网络主要面向传感器/执行器的低速网络,数据传输位速率一般小于10 kb/s,目前A类网的首选标准为LIN(LocalInterconnect Network)协议;B类网络主要面向独立模块间数据共享的中速网络,数据传输位速率在10~125 kb/s,目前B类网络主要采用低速容错CAN标准ISO11898-3;C类网络则主要面向高速、实时闭环控制的多路传输网,数据传输位速率在 125~1 Mb/s之间,欧洲的汽车制造商主要采用高速CAN标准ISO11898-2来实现该类网络。下面简要介绍一下CAN协议和LIN协议。

1986年2月,德国的Bosch公司在SAE大会上提出了CAN串行总线。时至今日,CAN已经形成国际标准,凭借自身的优点,不仅在汽车领域,而且在机械数控机床及传感器等领域都得到广泛应用。CAN总线的主要特点有:多主机的工作方式;最大传输速率可达1 Mb/s(通信距离最长40 m),直接通信距离可达10 km(速率小于5 kb/s);采用短帧结构,传输时间短;良好的检错能力;非破坏总线仲裁技术;较高的性价比。

LIN是1998年由BMW等五家汽车制造商、一家软件工具制造商以及一家半导体厂商联合提出的一个协议。LIN通信是基于SCI(UART)数据格式,采用单主/多从模式以及低成本的单线连接方式,最高传输速率可达20kb/s。LIN的从节点不用晶振或陶瓷振荡器就能实现自同步。出于以上技术特点, LIN总线实现成本较低,且完全能够满足A类网络的通信需求。

在实际的汽车电子网络中,A、B、C三类网络并不是完全独立的。为了完成车辆的控制及信息共享,不同网络间必须进行相应的数据交换。由于是三种不同的网络,它们之间的通信是不能直接进行的,而必须作相应的协议转换及数据处理后才能实现,这些工作是由网关来实现的。本文提出了一种网关的设计方案,用以实现高速CAN、低速CAN及LIN三种总线网络之间的通信。

1 网关总体结构

本文所讨论的网关其主要任务是解决车载网络中A、B、C三类网络的相互通信的问题,实现数据的存储转发及高、低速CAN协议之间或低速CAN与LIN协议之间的协议转换,以便在不同网络之间实现数据通信。网关主要分为4个部分:实现数据存储转发和协议转换的主控制器,用于与高速CAN网络连接的高速CAN 节点模块,与低速CAN网络连接的低速CAN节点模块以及与LIN网络连接的LIN节点模块。网关系统的电路框图如图1所示。

基于AT91SAM7A3芯片和CAN收发器实现CAN/LIN网关的设计

网关中三个节点电路分别与各自的网络相连,且实现各自对应的网络与主控制器之间的数据交换。这个数据交换过程是双向的,既包括从网络上接收数据并将数据存到主控制器中,又包括从主控制器相应的缓存器中读取数据并将其发送到自己对应的网络中。主控制器主要负责数据的存储及协议的转换,即将各个节点接收来的数据根据其目的网络的不同,分别存入不同的缓冲区,并且根据目的网络的不同,将数据转化为能够在目的网络上传送的数据格式。

2 网关电路设计

如上所述,网关的硬件电路主要由主控制器、高速CAN节点模块、低速CAN节点模块、LIN节点模块4部分组成。为了满足网关的正常通信要求,必须考虑主控制器的数据处理能力。另外,由于网关的工作环境为电磁干扰非常严重的汽车内部,故还须考虑网关的抗噪声干扰性能。网关的硬件设计简图如图2所示, AT91SAM7A3为网关的主控制芯片,TJA1020为LIN总线收发器,CTM1054为低速CAN收发器,CTM1050为高速CAN收发器。

2.1 主控制器的选择

实现数据的高效率、高质量的存储转发是网关的重要目标,而主控制器是网关的核心器件,它的性能好坏直接决定了网关的效率高低。主控器对接收到的数据进行缓存,因此主控制器需要有较高的存储容量。主控器还要对它所接收与转发的数据进行协议转换等数据处理,因此还要有较强的运算能力。

本设计选用了Atml公司的AT91SAM7A3作为网关的核心控制器。这是一颗基于ARM7TDMI内核的32位RISC处理器,具有执行速度快、效率高的特点,能够满足网关的数据处理要求。该芯片内置32 KB的SRAM和256 KB的高速Flash存储器,存储能力强,能够满足网关对数据存储的要求。另外,该芯片内部集成有2个功能强大的CAN2.OB的控制器,可以处理所有类型的帧结构(数据帧、远程帧、错误帧及过载帧),每个控制器有16个独立的缓存区(mailbox),十分有利于实现网关高速、大容量的数据处理。集成的 CAN控制器还能够减少器件数目和PCB布线数量,有利于提高系统的抗干扰性能。

2. 2 CAN节点设计

常用的CAN节点电路如图3所示,它主要由MCU、CAN控制器及CAN收发器组成。为了增强电路的抗干扰性,还需要在控制器与收发器之间增加一个隔离电路。

本网关中的CAN节点共有2个:高速CAN节点和低速CAN节点。由于在汽车中电磁干扰现象非常严重,仅靠单个的CAN收发器难以满足通信品质的要求,需要加上适当的隔离电路以提高电路的抗干扰性。

2个节点的MCU的功能由主控制芯片AT91SAM7A3实现,且AT91SAM7A3中集成了两个高性能的CAN控制器,可以分别作为高低速CAN节点的控制器。

常用的隔离电路采用高速光耦6N137实现CAN节点之间的信号隔离,并且采用电源隔离模块实现高速光耦的两个电源的隔离。但是这种设计无疑增加了PCB的走线,使电路的没计变得复杂,同时隔离电路的隔离效果也受到影响。

本设计采用广州致远电子有限公司生产的CTM系列的CTM1050和CTM1054,分别作为高低速CAN收发器。CTM系列的CAN收发器集成了CAN 收发器以及必需的隔离,即在一块芯片上实现了隔离电路和CAN收发器的功能。这样就不必单独设计隔离电路,提高了集成度,使得抗干扰性得到增强。

高速CAN收发器CTM1050,最高速率可达1 Mb/s,完全符合ISO11898-2标准的高速CAN通信,用它作为高速CAN网络接口的收发器(电路连接方法见图2)。容错CAN收发器 CTM1054,最高通信速率可达125 kb/s,完全符合ISO11898-3标准,用它作为低速CAN网络接口的收发器(电路连接方法见图2)。需要注意的是,在CTM1054的连接中,有 2个电阻R1和R2的阻值要根据低速CAN网络中节点的个数来确定。具体值的算法见CTM1054使用手册。

2.3 LIN接口设计

LIN总线是一主多从的总线连接方式,节点有主从之分。在本设计中,将LIN节点设计为主节点。LIN是一个基于单线串行的通信协议,对于硬件的要求比较简单。通常一个有SCI/UART接口的单片机和一个LIN收发器就可组成LIN节点。本设计利用AT91SAM7A3的UART口和LIN收发器 TJA1020组成一个LIN主节点。

TJA1020使用的波特率可从2.4~20 kb/s,有较好的保护功能:总线终端和电池引脚可防止汽车环境下的瞬变、总线终端对电池和地的短路保护以及过热保护等,可以作为汽车通信中的LIN通信接口(具体电路连接见图2)。

3 网关软件设计

网关的软件系统主要包括主监控程序、数据的发送、数据的接收、数据的处理(包括协议转换和缓冲区内数据的读写处理)等几部分。

3.1 主监控程序

如图4所示,在主控制器AT91SAM7A3中划出4块缓冲区BUF1~BUF4,每一块缓冲区中的数据都有明确而且唯一的来源和目的地。主监控程序主要通过循环依次查询BUF1~BUF4中的存储情况,来决定是否发送数据以及将数据发送给谁。

当高速CAN网络上有数据需要接收的时候,通过高速CAN模块接收数据,对接收到的数据进行处理后,将其存到缓冲区BUF1中,再由低速CAN模块将其发送到低速CAN网络上;当LIN网络上有数据需要接收时,通过LIN总线模块接收数据,对接收到的数据进行数据格式转换(LIN格式的报文帧转换为CAN 格式的报文帧),再将其存入到缓冲区BUF4中,并由低速CAN模块将其发送到低速CAN网络上;当低速CAN网络上有数据需要接收时,先接收数据,然后判断数据是发送到高速CAN总线,还是发送到LIN总线,根据判断结果对数据进行处理,存入相应的缓冲区(如数据是发往高速CAN总线,则存入BUF2,否则存入BUF3)。

3.2 数据的发送

数据的发送由发送子程序完成,网关中主要有3个发送子程序,分别对应两路CAN控制器以及一路 LIN发送器。高速CAN的发送子程序负责发送BUF1中的数据,LIN的发送子程序负责发送BUF3中的数据,低速CAN的发送子程序负责发送BUF2 和BUF4中的数据。数据的发送采用查询总线状态的发送方式:查询总线的忙闲情况,如果总线忙,则退出发送子程序,进行其他的工作;如果总线空闲,则发送数据。发送完1帧数据后,再检查与之相应的缓冲区的状态。如果为空,则退出发送子程序;如果非空,则再检查总线的忙闲状态。如果忙,则退出发送子程序;如果空闲,则发送数据。然后再开始新一轮的数据查询发送过程。图5为高速CAN向低速CAN发送的流程,其他的发送子程序过程与此类似。

3.3 数据的接收

数据接收是从总线上接收数据,进行必要的协议转换,再将转换后的数据存人相应的缓冲区。网关中有3个接收子程序,分别对应两路CAN控制器及一路LIN发送器。数据接收采用中断方式,由于不同网络有不同的实时性要求,因此为3个接收程序设定了不同的中断级别。高速CAN的实时性要求最高,中断级别也设为最高;而LIN总线的实时性在三者中最低,故中断级别也最低。当一个接收中断发生后,进入接收中断子程序,判断相应的缓冲区是否已满(低速CAN的接收程序在接收到数据后需要根据数据的目的网络确定缓存区为BUF2还是BUF3)。如果缓冲区已满,则产生一个溢出错误标志;如果没有满,则将数据进行相应的协议转换,并将转换后的数据存入相应的缓存区,退出中断并完成接收。图6所示为低速CAN数据接收过程的简要流程。

3.4 数据的处理

网关的数据处理是指协议的转换和数据在缓冲区的存储与转发。每当接收到一组数据时,首先进行协议转换,然后再将其存入到相应的缓存区。高低速CAN的协议相同,并不需要转换,因此主要是进行CAN协议和LIN协议之间的转换。

CAN协议和LIN协议都是以帧(frame)为数据单位进行通信的。在进行LIN协议到CAN协议的转换时,首先是将LIN帧分解,从标识符场 (identfield)提取出其中的ID标识符,从数据场(data field)提取出有效数据,然后根据这些信息封装成符合要求的CAN帧格式。CAN协议到LIN协议的转换过程亦是如此。先将CAN帧分解,从仲裁域 (arbitration field)和数据域(data field)中提取出有用信息,然后封装成符合要求的LIN帧格式。

数据的4个缓冲区BUF1~BUF4为FIFO(First InFirst Out)缓冲区,本文采用循环队列(circular queue)来实现数据的先进先出。两个指针Read和Write分别指示队头元素和队尾元素在缓冲区空间中的位置,它们的初值在队列初始化时均应置为 0,每读取或写入一次数据,都要对缓冲区的参数进行调整。写数据时,将新元素插入Write所指的位置,然后将Write加1;读数据时,删去Read所指的元素,然后将Read加1并返回被删元素。

4 网关通信测试

将网关的高速CAN接口和低速CAN接口分别与单独的CAN节点电路相连,LIN接口与单独的LIN从节点相连,组成测试网络。测试的主要内容为高速 CAN和低速CAN之间的通信,低速CAN和LIN网络之间的通信。高速CAN网络采用速率为500 kb/s,低速CAN网络采用的速率为100kb/s,LIN网络采用的速率为10 kb/s。利用PC机的串口发送测试数据,同时在另一个串口终端上进行数据的监测。测试结果表明,发送数据内容与监测到的数据内容一致。

5 总 结

以AT91SAM7A3为核心设计的一款CAN/LIN混合网关,实现了汽车网络中高速CAN总线、容错CAN总线及LIN总线三类网络之间的通信,使汽车中的各类网络的信息能够有效共享,实现了不同性质网络的互联。

责任编辑:gt

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

    关注

    450

    文章

    49317

    浏览量

    415545
  • 收发器
    +关注

    关注

    10

    文章

    3321

    浏览量

    105334
  • 控制系统
    +关注

    关注

    41

    文章

    6353

    浏览量

    109917
收藏 人收藏

    评论

    相关推荐

    CAN收发器电路原理#新能源

    CAN
    未来加油dz
    发布于 :2023年05月09日 22:56:07

    我想问下 AT91SAM7A3-AU 是用在CAN/LIN息线的汽车混合网关是用在什么汽车上的 清教下哪位大神知道是用在哪个汽车上的

    我想问下 AT 91SAM7A3-AU 是用在 CAN/ LIN息线的汽车混合 网关是用在什么汽车上的清教下哪位大神知道是用在哪个汽车上的或是用在哪个机子上的
    发表于08-15 14:30

    一种基于Salvo的通用CAN/LIN网关

    CAN/ LIN 网关是基于 CAN/ LIN总线分级网络控制系统的核心部件。本文探讨一种通用 CAN
    发表于08-15 09:34 13次下载

    CTM8251ACTM8251AT通用CAN隔离收发器产品

    CTM8251 A是一款带隔离的通用 CAN 收发器 芯片,该 芯片内部集成了所有必需的 CAN隔离及
    发表于03-13 15:09 158次下载

    RS-485收发器CAN收发器有什么区别

    协议。两人利用静电放电(ESD)和电压故障干扰MAX13054 A CAN 收发器背板,演示IC可靠的操作性能。
    的头像 发表于10-11 10:26 8331次阅读

    MRT1040DL通用CAN通信收发器芯片的中文数据手册免费下载

    MRT1040DL是一款带隔离的通用 CAN 收发器 芯片, 该 芯片内部集成了所有必需的 CAN隔离及 CAN
    发表于10-18 08:00 25次下载
    MRT1040DL通用<b class='flag-5'>CAN</b>通信<b class='flag-5'>收发器</b><b class='flag-5'>芯片</b>的中文数据手册免费下载

    深入探析CAN收发器各项参数

    CAN 收发器是连接 CAN控制系统与 CAN总线网络的桥梁,当选型 CAN 收发器时应该注意哪些参数?本
    的头像 发表于12-15 09:34 1.4w次阅读
    深入探析<b class='flag-5'>CAN</b><b class='flag-5'>收发器</b>各项参数

    关于兼容CANFD的系统基础芯片(SBC)的性能分析和应用介绍

    CAN 收发器也可以在 SBC 中使用。这些是 芯片提供的附加功能。英飞凌的 Lite SBC 系列包括 LDO (低压差)稳压 和 DC/DC 模块以及一个
    的头像 发表于09-24 10:28 1.5w次阅读
    关于兼容<b class='flag-5'>CAN</b> FD的系统基础<b class='flag-5'>芯片</b>(SBC)的性能分析和应用介绍

    关于英飞凌CANFD收发器芯片的作用分析

    符合ISO11898-2:2016的TLE925x 收发器外,英飞凌还提供配套系统级 芯片——TLE9278 Multi- CANPower-SBC产品系列。
    的头像 发表于09-24 17:30 1.4w次阅读

    CAN控制收发器

    一、 CAN控制 CAN控制器用于将欲 收发的消息(报文),转换为符合 CAN规范的 CAN帧,通过
    发表于12-04 11:21 28次下载
    <b class='flag-5'>CAN</b>控制<b class='flag-5'>器</b>和<b class='flag-5'>收发器</b>

    CAN收发器的时序考虑

    CAN 收发器的时序考虑
    发表于11-15 19:45 6次下载
    双 <b class='flag-5'>CAN</b> <b class='flag-5'>收发器</b>的时序考虑

    NXPCAN收发器的特点及应用

    面对各种不同种类的 CAN通信 收发器,你是否知道该如何选型?NXP推出了多种类型的 CAN 收发器,它们除了能满足基本的 CAN通信需求外,每种系列
    的头像 发表于09-05 14:05 2348次阅读
    NXP <b class='flag-5'>CAN</b><b class='flag-5'>收发器</b>的特点及应用

    CAN控制CAN收发器CAN驱动的区别是什么?

    CAN总线结构中, CAN控制 CAN 收发器CAN驱动
    的头像 发表于01-30 09:44 2534次阅读
    <b class='flag-5'>CAN</b>控制<b class='flag-5'>器</b>、<b class='flag-5'>CAN</b><b class='flag-5'>收发器</b>、<b class='flag-5'>CAN</b>驱动<b class='flag-5'>器</b>的区别是什么?

    汽车CAN收发器的作用、原理及构成

    随着汽车电子技术的飞速发展,汽车 CAN 收发器作为汽车电子系统中的重要组成部分,其重要性日益凸显。汽车 CAN 收发器不仅关乎到汽车内部各个模块之间的通信,还涉及到汽车的安全、性能以及智能化
    的头像 发表于05-24 15:33 927次阅读

    CAN收发器CAN控制的区别

    CAN总线系统是现代工业自动化和汽车控制系统中常用的通信协议。在 CAN总线系统中, CAN 收发器CAN控制
    的头像 发表于05-28 15:44 1204次阅读