基于ARM处理器的CAN-Ethernet通信模块实现

发布者:明理厚德最新更新时间:2007-08-20 来源: 测控技术关键字:串行  地址  通路  存储 手机看文章 扫描二维码
随时随地手机看文章
近20 年来工业测控系统发展的趋势是:分散控制和集中管理、标准化和开放性。工业测控系统从传统的集中测量控制系统转向网络化的集散控制系统。随着现场总线技术高速发展和标准化程度不断提高,以现场总线技术为基础的开放型集散测控系统—现场总线测控系统得到了广泛的应用。同时,以太网的应用也迅速向工业测控系统渗透,在工业自动化应用中异军突起。

这种趋势的出现与计算机技术、信息技术、网络通信技术的高速发展相关。现代工业系统信息交换的需求也已经从管理层内部迅速覆盖到控制、现场设备等各个层次,连接上层网络和现场总线的通信设备成为工厂自动化系统中的关键设备之一。CAN-Ethernet通信模块,是一种直接连接以太网和CAN现场总线的设备,有效解决了控制系统中现场总线和上层信息管理层的互联问题,使自动化系统中的信息交换可以深入到现场设备一级。

1  CAN 总线和以太网的连接

现有的CAN 总线到以太网的通信实现方案中,采用较多的是使用一台连接以太网的计算机,在计算机中安装一块内置式CAN通信板卡;或者通过计算机并行和串行接口外接CAN 的通信模块。这种方法有一定局限性,例如,使用计算机体积大,成本高;计算机故障后的重启速度慢,这可能严重影响系统的工作。采用基于ARM微处理器的单板机系统建立CAN-Ethernet 通信模块,可以很好地解决上述问题,降低系统的成本,提高其性能。CAN-Ethernet通信模块连接以太网和CAN 总线的结构如图1 所示。在以太网和CAN 总线之间,可以挂接一个通信模块连接两种网络,也可以使用多个通信模块形成多个通路。对于第二种情况,以太网上的计算机可以通过指定IP地址和上层协议的端口选择通路。

           图1  通过通信模块连接以太网和CAN 总线

2  通信模块的硬件设计

信模块的硬件核心采用高性能的ARM处理器S3C44B0x。它是一种精简指令处理器,可以在32位指令字的ARM模式下和16位指令字的Thumb模式下工作,设计者可以根据需要在性能和代码大小之间进行折衷;片内有8KB的高速静态RAM,既可以作为高速缓存,也可以作为片内存储器使用;片内外设包括异步和同步串行接口、I2C接口、LCD控制器及接口、实时时钟等。ARM处理器还具有低能耗和高性价比,非常适用于构建性能较高的嵌入式系统。

通信模块使用2片39VF040芯片,位扩展后组成512K/16bit共1MB的Flash ROM作为程序和配置数据的存储空间,使用1片62LV25616芯片组成256K/16bit 共512B的静态随机存储器。CAN总线通信控制芯片选用了Philips公司的SJA1000T,它是一种独立的CAN 总线通信控制器,仅需要CPU给出必要的指令,控制器就可以自动完成链路层以下的收发工作,并通知CPU总线的工作状态。以太网通信控制芯片采用了台湾Realtek公司的RTL8019as,它是一种ISA 接口的10Mb/s以太网卡芯片,内部包含了以太网媒体访问控制和物理层驱动,并带有16KB的片上缓冲RAM。

2. 1  处理器和5 V 系统数据线的连接

系统中的处理器S3C44B0x 和存储器芯片都使用3.3 V 的IO电压,CAN总线接口、以太网接口则使用5V的工作电压。 S3C44B0x 的数据、地址和控制信号线可以直接驱动这些外围电路芯片(参考S3C44B0x、SJA1000、RTL8019as 数据手册) ,但是外围电路芯片输出的高电平可能损坏处理器和直接挂接在处理器数据线上的其他芯片。因此,数据线上应该使用总线转换器进行3.3/5V电平转换。系统选用了兼容3.3 V和5V的信号电平的双向总线收发器LCX245芯片。LCX245 的控制信号包括方向控制端DIR(0 :B →A ,1 :A →B) 和使能控制端OE(0 :接通,1 :隔断) ,这些控制信号将使用GAL芯片产生。图2 为系统的硬件连接示意图。

            图2  系统的硬件连接示意图

GAL 芯片选用GAL16V8D-15LP ,它的传播延迟时间为15ns ,反馈延迟时间为7ns ,适于较高速度的工作。除了产生总线收发器芯片的控制信号外,同一片GAL 还用来产生SJA1000 需要的控制信号。根据处理器S3C44B0x 的输出信号, 包括为SJA1000分配的地址组选通信号nGCS3和RTL8019分配的地址组选通信号nGCS4、读写信号线nOE和nWE,可以产生总线收发器LCX245所需要的DIR和OE信号,各信号如图3 所示。

            图3  LCX245 控制信号的产生

nGCSx 是处理器的地址组选通信号,S3C44B0x 将外部地址空间从地址0 开始,每32M划分为一个组(Bank ) ,外部寻址时地址线A0 ~ A24 输出组内地址,该地址所在的组的组选通信号同时有效。图中虚线代表写操作时的DIR 信号,实线为读操作的信号。从图中可以得到使用ABEL 语言描写的的信号生成逻辑式为:  
 
OE = (nOE &nWE) # (nGCS3 &nGCS4 &nGCS5) ; 
DIR = nOE # (nGCS3 &nGCS4 &nGCS5) ;   

但是为了使系统更加稳定地工作,应保证OE 信号有效时DIR 信号不发生变化,也就是说进行读操作时图中OE 低电平脉冲的前沿应晚于DIR ,后沿应早于DIR ,这样将出现反馈逻辑,可以使用类似于同步时序电路的设计方法设计。图4 是OE 信号和DIR 信号的次态卡诺图,次态符合上述要求,并且在输入一定的状态下,OE 信号和DIR 信号总是每次改变一个,逐次进入最后的稳态状态(粗体字表示) 。图中“×”表示不会出现的输入状态。

            图4  OE 和DIR 次态 卡诺图

根据卡诺图重新写出的次态逻辑产生式,消除单独输入(包括OE 和DIR 的当前状态) 变化可能引起的竞争- 冒险现象后为:

OEn = (nOE &nWE) # (nOE & ! DIR) # (nWE &DIR) # (nGCS3 &nGCS4 &nGCS5) ; ///

DIRn = ( ! OE &DIR) # (nOE &DIR) # (nOE &OE) # (nGCS3 & nGCS4 &nGCS5) ;

编译GAL 逻辑时应严格按照逻辑式生成与或逻辑。

2. 2  CAN 总线通信控制芯片SJA1000 的读写

CAN总线通信控制芯片SJA1000 没有提供单独的地址线,而使用可以与Intel 和Motorola系列微控制器兼容的分时复用地址/ 数据线。在一个读写周期内,微控制器首先输出操作地址并使地址锁存信号ALE 有效,SJA1000 在ALE 信号的下降沿将操作地址锁在片内;之后微处理器发出读写信号进行数据传输。但S3C44B0x 的数据线和地址线是分离的,对SJA1000 的读写操作需要模拟微控制器,先在数据线上写一个操作地址,并模拟产生一个ALE 信号锁存这个地址,之后进行正常的读写操作。系统使用地址线ADDR0 区分地址传输和数据传输:写奇地址时,不选通SJA1000 芯片,但给出一个有效的模拟ALE 信号;读写偶地址时,选通SJA1000 读写数据。另外,系统同时有两路CAN 总线接口,读写操作根据地址线ADDR1 区分两个SJA1000 芯片,两个片选信号和ALE 信号都要通过GAL 芯片产生,各信号如图5所示。

           图5  SJA1000 控制信号的产生

图中虚线是向SJA1000 传输和锁存地址的过程,实线是读写操作的过程。用ABEL 语言书写的各信号产生逻辑式为:

CAN-CS = nGCS4 # ADDR0 ;

ALE = ! nWE &ADDR0 & ! nGCS4 ;

对SJA1000 的操作地址如下:地址锁存向0x08000001端口写地址;数据读写通过地址0x08000000。

3  通信模块的软件设计

通信模块和CAN 总线上的设备节点之间直接通过SJA1000收发CAN 总线报文进行通信,报文中的数据格式可以是基于CAN 总线的上层标准协议,也可以由用户定义。为了方便与以太网上计算机的通信,CAN-Ethernet 通信模块在以太网一端使用UDP协议,这样,计算机上的软件可以使用操作系统提供的网络访问服务。

每一个CAN-Ethernet 通信模块需要设定局域网内一个惟一的IP地址,通过固定的UDP端口和计算机通信。模块和计算机之间既可以使用对单点IP的通信,也可以在UDP端口发送广播报文。在以太网一端,通信模块接收到UDP 报文后,将其中的信息组织成CAN 总线报文发往CAN 总线;在CAN 总线一端,通信模块接收报文标识能够通过本节点接收码和接收掩码设置的CAN 总线报文,并封装为UDP 报文,转发到以太网上。各节点IP 地址、UDP工作端口和CAN报文接收掩码等设置在系统初始化时进行。

3. 1  通信控制芯片的初始化和收发操作

对SJA1000T的基本操作如下:

①初始化:硬件复位,进入复位方式; 设置为BasicCAN 模式,CDR = 0x08 ;设置波特率控制字BTR0 ,BTR1 ;设置接收码和接收掩码ACR、AMR;完成设定,进入工作模式,CR = 0x1E。   

②发送:将CAN 总线报文写入SJA1000T 发送缓冲区TX2IDR1~2 , TXDR1~8 ;写发送命令,CMR = 0x01。

③接收:从RXIDR1~2、RXDR1~8 读出CAN 一帧CAN 总线报文;将SJA1000T 的接收缓冲区窗口滑动到下一帧,CMR =0x04。

RTL8019AS内部有页地址为0x40~0x79 的256个缓冲页,每页256B。这些缓冲页的一部分作为接收缓冲区,起始页地址和结束页地址通过PSTART、PSTOP 寄存器配置,剩余可以作为发送缓冲区使用。硬件把接收缓冲区作为环形缓冲区使用,CURR寄存器和BNRY寄存器分别指明缓冲区中未使用部分的起始和结束页地址。硬件接收到数据后会自动修改CURR 的值,而BNRY需要读出一帧数据后由软件修改;对RTL8019AS的基本操作如下:

①初始化:硬件复位操作,进入停止方式;写入物理地址到PR0~PR5 ,写入0x00 到多点接收地址寄存器MAR;设置内部发送缓冲区器起止页地址到PSTART、PSTOP;写入当前
页地址到CURR和页地址界寄存器BNRY中;进入正常工作方式,CR =0x02。

②发送:将以太网报文载入在RTL8019AS中设置的发送缓冲区中;写发送起始页地址到TPSR ,写发送内容长度到TBCR0~1 ;写发送命令,CMR = 0x1A。

③接收:从在RTL8019AS中设置的接收缓存页中读出一帧以太网报文;根据报文长度改变页地址界限BNRY的值。

3. 2  UDP 和CAN 报文的转换

CAN - Ethernet 通信模块收到CAN 总线报文时,将整个报文封装在一帧UDP 报文中;接收到目的端口与自己的工作端口相符的UDP 报文时,取出其中的数据段作为一帧CAN 总线报文。以太网报文到CAN 总线报文的具体转换过程如下:

①如果接收到的以太网报文包含IP 报文,分解出IP 报文,否则抛弃这帧报文;

②如果IP 报文的目的地址匹配,并且包含一帧UDP 报文,分解出UDP 报文,否则抛弃;

③如果UDP 报文的目的端口匹配,分解出其中的CAN 总线报文,否则抛弃。

CAN 总线报文到UDP 报文的转换过程是:

①接收到的CAN 总线报文装入UDP 报文的数据段,计算校验和,完成UDP报文封装;

②加上IP 报文头部,计算校验和,完成IP报文封装;

③加上以太网报文的头部,报文尾部的校验和不需要软件完成,RTL8019AS在发送时会自动添加。

为了减少在转换过程中的数据拷贝,定义了如下数据结构。从CAN总线上收到的报文直接放在Frame结构体的can[ ]成员中,并记录长度,封装为UDP报文的过程就是填充Frame结构体中其他成员的过程;从以太网上收到的报文逐字节放入Frame结构体中,CAN 报文就包含在can[ ]成员中。

struct EthHead {
unsigned char DstPhyAddr[6 ] ;  / / 以太网目的地址
unsigned char SrcPhyAddr[6 ] ;  / / 以太网源地址
unsigned short Prt ;  / / 协议标识
} ;
struct IPHead {
unsigned char VerLen ;  / / 版本号和头长度
unsigned char ServType ;  / / 服务类型
unsigned short Len ;  / / 长度
unsigned short ID;  / / 报文ID
unsigned short FlagAndFrag ;  / / 标记和分段
unsigned char TTL ;
unsigned char Prt ;  / / 协议标识
unsigned short HdChksum;  / / 头校验和
unsigned char srcIP[4 ] ;  / / 源IP 地址
unsigned char dstIP[4 ] ;  / / 目的IP 地址
} ;
struct UDPHead {
unsigned short srcPort ;  / / 源端口号
unsigned short srcPort ;  / / 目的端口号
unsigned short Len ;  / / 长度
unsigned short Chksum;  / / 校验和
} ;
struct Frame {
 struct EthHead ethhd ;
 struct IPHead iphd ;
 struct UDPHead udphd ;
unsigned char can [ 10 ] ;  / / 放置CAN 报文 

  short canlen ;  / / 记录收到的CAN 报文长度
} ;

3. 3  通信程序的实现

处理器对SJA1000T和RTL8019AS 的操作都使用了中断方式,通信模块的软件程序可以分成SJA1000T 中断服务程序、RTL8019AS中断服务程序和主程序3 个部分,是典型的前、后台处理结构。在中断服务程序中,将收到的CAN 总线报文和以太网报文读入内存中的缓冲区,并累加缓冲区内还未处理的报文计数。在主程序循环中,轮流处理两个缓冲区中的报文,并减小报文计数值。图6 是SJA1000T的中断服务流程、RTL8019AS中断服务流程、主程序的流程。由于SJA1000T内部的接收缓冲区只有64B ,所以在程序中定义了容纳32个Frame结构体数组can- rbuf [ ]并组成环形缓冲区。同时也定义了相同大小的数组eth- rbuf [ ]组成以太网接收的环形缓冲区。

            图6  通信模块软件流程图

在调试过程中发现,如果转发过程被特定的中断程序打断,可能发生报文计数错误;如果向RTL8019AS写入待发送报文的过程被以太网接收中断打断,就无法恢复写入过程了。因此在转发过程中应屏蔽相应的中断。

4  结束语

采用上述方法实现的CAN-Ethernet 通信模块,解决了以太网和现场总线CAN 总线之间互联问题,可以根据应用的需求,进行灵活的配置和改进,提高系统的性能和可靠性。实际证明,在局域网环境下模块工作可靠,在以太网负载适中时,只有很小的通信延迟。它为CAN-Ethernet 的互联提供了低成本、高性能及灵活的解决方案。

关键字:串行  地址  通路  存储 引用地址:基于ARM处理器的CAN-Ethernet通信模块实现

上一篇:基于Modbus协议实现单片机与PLC之间的通讯
下一篇:用CPLD实现DSP2407A与S3C4480的通信

推荐阅读最新更新时间:2024-03-30 21:24

从PC串行口实现简单红外数据传输
常有这种情况,需要在没有直接电缆连接的情况下,将一些位或字节的数据送给一个微控制器。实现这一目标的一种简单方式是使用到处可见的红外接收器,如Vishay公司的TSOP17xx或类似接收器,它们一般用于红外遥控设备,如电视和录像机。这些装置很容易实现,因为它们不需要外接元件。这些接收器通常使用一个38kHz的脉冲载波,并带有一个放大器、自动增益控制和解调器。     简单应用的主要问题是建立发射机,它需要一个38kHz的起始-停止振荡器、附加电源,以及毫秒与亚毫秒范围内的调制脉冲。用PC操作系统难以控制这些要素。另一方面,PC串行端口的标准传输速率为38400bps,用一个简单的倍频器和两只红外LED就可以生成精确的38.4
[模拟电子]
从PC<font color='red'>串行</font>口实现简单红外数据传输
iSuppli:2013年汽车硬盘出货量将接近2006年的五倍
数字多媒体信息娱乐系统在轿车产业中的爆炸性增长,正在推动汽车厂商把硬盘用于音乐、视频和其它数字内容的存储和回放。 预计2013年用于汽车信息娱乐系统的硬盘出货量将从2006年的350万个增长到1,660万个,几乎增长四倍。2006-2013年汽车硬盘出货量的年复合增长率将达25.1%,将成为未来几年汽车产业中增长最快的存储解决方案。 “汽车信息娱乐的发展,为用户提供了一个多媒体环境,有望超过其家中的娱乐系统。” iSuppli公司的汽车电子首席分析师Richard Robinson表示。“在不远的将来,汽车将需要接收和存储来自无线电、电视和WiMAX等其它数据传输系统的广播数字内容。这方面的要求正在影响汽车制造商的有关策略,它
[焦点新闻]
STM32-Flash做为存储器储存数据
说到STM32的FLSAH,我们的第一反应是用来装程序的,实际上,STM32的片内FLASH不仅用来装程序,还用来装 芯片 配置、芯片ID、自举程序等等。当然, FLASH还可以用来装数据。 自己收集了一些资料,现将这些资料总结了一下,不想看的可以直接调到后面看怎么操作就可以了。 FLASH分类 根据用途,STM32片内的FLASH分成两部分:主存储块、信息块。 主存储块用于存储程序,我们写的程序一般存储在这里。 信息块又分成两部分:系统存储器、选项字节。 系统存储器存储用于存放在系统存储器自举模式下的启动程序(BootLoader),当使用ISP方式加载程序时,就是由这个程序执行。这个区域由芯片厂写入BootLoader,
[单片机]
东芝的存储业务出售仍然存在不确定性
10月24日,日本东芝公司召开股东大会,大会正式批准东芝将闪存业务“东芝存储公司”以两万亿日元(约合175亿美元)的价格,转让给美国私募股权投资公司贝恩资本领军的财团。   事实上,东芝出售闪存芯片业务的协议在9月28日就已经达成,当时东芝董事会宣布他们已同贝恩资本牵头的财团签署最终协议,将以2万亿日元的价格出售闪存芯片业务子公司。收购财团中除了贝恩资本之外,还包括苹果、戴尔、希捷、韩国SK海力士等公司。 贝恩资本此前表示,将联合收购伙伴向东芝存储公司注入90亿美元的资金,保证其后续的运营和研发,另外根据资本市场状况,东芝存储公司将在几年内在东京股市独立上市。 东芝必须在明年三月底财年结束之前,完成这一转让交易,以便
[嵌入式]
基于Z85C30的多协议串行通信设计
摘要:简要从硬件和软件两方面介绍一种嵌入式的多协议串行通信设计方案。该设计方案采用多协议串行通信控制器Z85C30及外围电路开发,通过软件编程,可满足各种串行通信要求,如异步、按字节同步、按位同步等通信格式。 关键词:嵌入式系统 串行通信控制器(SCC) Z85C30 引言 我们在嵌入式系统的开发过程中,经常需要设计串行通信口,用以同其它设备或计算机网络交换数据。针对不同的应用场合及不同的通信格式,在硬件设计方面有许多不同的芯片可供选择,如Intel 8251A、Intel 8274、Intel 82530等。采用ZILOG公司的串行通信控制器Z85C30进行设计,和其它器件相比,具有功能强、速度快、外部逻辑少等优点。 1
[网络通信]
江苏淮安第四代存储器项目预计明年量产
在江苏新一轮的造芯计划中,除了南京、无锡、苏州等城市,淮安也在努力争取自己的行业地位 据人民网消息,明年一季度,江苏时代芯存半导体有限公司即将实现量产,年销售额预计可达45亿元。 江苏淮安PCM生产项目总投资130亿元,一期投资43亿元,于2016年9月28日落户国家级淮安高新技术产业开发区,用时9个月实现厂房封顶,3月22日首台设备进厂。项目全面建成后将达到年产10万片12英寸相变存储器的产能,年可实现销售45亿元。 据此前淮安市台办消息,淮安已成为大陆地级市中唯一同时拥有两个12英寸高水准项目(另一个为德淮半导体项目)的地区。 PCM是业界公认的第四代相变存储器的最成熟的技术,公司总经理邢猛说“第四代存储器读取
[手机便携]
STM32的地址分配
一.存储器组织 注:每一个外设都对应一个寄存器组,如定时器TIM2对应的寄存器地址为0x40000000~0x400003FF. 二.嵌入的SRAM以及嵌入的闪存 1.嵌入的SRAM可以以字节,半字,全字访问,这里SRAM的起始地址为0x20000000. 2.闪存存储器有主存储块和信息块组成。 注:有关闪存寄存器的详细信息,请参考《STM32F10xxx闪存编程手册》。
[单片机]
NAND Flash嵌入式存储系统结构分析
    目前市场上闪存芯片主要有两类,即NAND Flash(Not And Flash ROM)和NOR Flash(Not Or Flash ROM)。前者具有容量大、读写速度快、芯片面积小、单元密度高、擦除速度快、成本低等特点,更适合于大批量数据存储的嵌入式系统。如今Windows仍是桌面系统的主流,对FAT文件系统提供了天然的支持。然而就技术而言,FAT文件系统并不适合Flash,因为Flash设备并不是块设备[1],为了不破坏兼容性,并在NAND型闪存中应用FAT文件系统,国际上提出了闪存转译层FTL(Flash Translation Layer)的解决方案。   1 NAND Flash嵌入式存储系统结构  
[嵌入式]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
最新工业控制文章
换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved