基于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通信模块实现

上一篇:VoIP中语音压缩编码技术的研究与性能分析
下一篇:AT91RM9200理器同步串口SSC的特性分析与应用

推荐阅读最新更新时间:2024-05-07 15:59

arm地址线的链接方式
zj2440访问sdram时,统一编址始终会发32位的地址寻址,由深入理解sdram之基本特性的理解这篇文章可知, 行地址bit ,列地址 bit , L-Bank选择 bit ,发现bit 并没有参与译码,这时为何呢? 因为没有必要,一张图就全都明白了 由上图可知,当屏蔽了地址线0,1后 0x00- 0x11即发送地址0x00或者到地址0x03, 其地址总线都是0x00,此时获取的都是从地址0x0至地址0x03上的数据 同理 0x100- 0x111即发送地址4或者到地址7, 其地址总线都是0x100,即地址4,所得到的都是从地址4至地址7的数据,按此类推
[单片机]
美光推出全新旗舰级 NVMe 固态存储系列
● 美光科技推出采用 NVMe™ 的全新 Micron® 9200 固态硬盘 (SSD),实现真正的存储创新 ● 美光 9200系列SSD 充分发挥 3D NAND 和 NVM Express 的技术优势 ● 美光科技为企业数据中心和云供应商提供最新技术,帮助他们应对当今数据洪流,取得更出色的业务成果 ● 凭借行业领先的性能,美光 9200系列SSD 能够最大限度地提高应用吞吐量并减少延迟,从而提高数据访问速度 美国爱达荷州博伊西,2017 年 8 月 8 日——美光科技有限公司(纳斯达克股票代码:MU)推出了旗下最新的旗舰级性能固态存储产品系列——Micron® 9200 系列 NVMe™ 固态硬盘(SSD)。具备创新型架构
[嵌入式]
针对MCS96系列单片机的段式管理的大容量数据存储器扩展技术
MCS96系列单片机是一种16位字长,比MCS51系列单片机功能更全、性能更高的单片机,在仪器仪表、过程控制等领域应用极为广泛。在采用MCS96系列单片机的应用开发中,我们碰到一个难题:当需要大容量的数据存储时,数据存储器的扩展如采用与MCS51系列单片机同样的方法则无法工作。因为其内存体系结构采用程序存储器与数据存储器统一编址的普林斯顿结构,程序存储器的地址与数据存储器的地址不能相同;而MCS51系列单片机采用程序存储器与数据存储器分开编址的哈佛结构,程序存储器的地址与数据存储器的地址不冲突,可以相同,因而其数据存储器扩展容易,而且整个数据存储器地址空间连续。MCS96系列单片机的普林斯顿内存体系结构决定了不能简单采用与MC
[单片机]
MSP430程序库<五>SPI同步串行通信
SPI总线系统是一种同步串行外设接口;是一种高速的,全双工,同步的通信总线,并且在芯片的管脚上只占用四根线,节约了芯片的管脚,同时为PCB的布局上节省空间,提供方便,正是出于这种简单易用的特性,现在越来越多的芯片集成了这种通信协议。 许多的芯片都用这种协议通信:EEPROM、Flash、实时时钟、AD转换器、数字信号处理器等:MSP430的USART模块不仅能够实现异步模式(见:MSP430程序库 二 UART异步串口),而且支持同步串行通信(即SPI模式);其SPI支持3线、4线操作,支持主机模式和从机模式,字符长度可以7位或8位等。由于要用AD7708芯片完成AD采样,AD7708是通过SPI与其它设备通信的;本程序比较简化,
[单片机]
MSP430程序库<五>SPI同步<font color='red'>串行</font>通信
上海知产法院去年受理案件同比倍增,涉及手机芯片、存储
4月22日,上海知产法院发布《2020年知识产权司法保护状况白皮书》(以下简称《白皮书》)。 2020 年,上海知识产权法院共受理各类知识产权案件5279件,审结4789件,同比分别增长111.5%和122.23%。在受理的全部案件中,收案数位居前五位的案件分别是专利案件1973件,同比增长75.69%;商标案件1622件,同比增长654.41%;著作权案件841件(不包括计算机软件著作权案件), 同比增长94.23%;计算机软件著作权案件509件,同比增长9.7%; 特许经营合同案件127件,同比增长36.56%。 在受理的一审案件中,专利、计算机软件、技术秘密、技术合同等技术类案件共2512件,占一审收案数量的98.70%。
[手机便携]
陈南翔就任长江存储执行董事长
集微网消息,近日,陈南翔出任长江存储执行董事长 2020年9月1日,紫光集团下发员工信宣布前华润微电子有限公司常务副董事长陈南翔加入紫光集团担任集团联席总裁。 陈南翔在加入紫光集团前,除担任华润微电子常务副董事长并主持公司全面工作外,还兼任华润润科微电子产业投资基金董事长、投决会主席。在服务华润电子的18年期间,曾经先后兼任华润晶芯半导体有限公司董事总经理、华润矽威科技有限公司董事总经理、华润微电子研发中心总经理。
[手机便携]
EE架构演变和工业机器人发展对存储的新需求
随着汽车行业的研发不断向前发展,以及EE架构本身的演变,使得区域算力提升,并且和云端计算结合。在这样的背景下,边沿计算的处理已成为下一代汽车所必须。复杂高效的互联互通能力以及车辆内外部的集成系统是每个车企重点投资的垂直整合技术。而关键的信息,需要被可重现事故过程的数据记录系统 EDR (Event Data Recorder) 记录下来,这个俗称 “汽车黑匣子”主要记录车辆在碰撞前、碰撞时、碰撞后三个不同阶段中汽车的关键运行数据,例如行车速度、方向盘转向速度、车辆制动状态等参数,为交通事故的调查分析提供客观、准确的数据。 汽车技术的发展,使得电子系统需要使用存储器,那么在这里存储到底有哪些作用呢?哪些存储器值得大家关注
[机器人]
Nordic助力蜂窝IoT跟踪设备监控存储或运输中的货物
Aovx G系列跟踪器设备使用Nordic nRF9160 SiP实现 LTE-M/NB-IoT 室内和室外位置监控 挪威奥斯陆 – 2022年6月23日 – 位于国内的 合肥云息通信技术有限公司 (Aovx) 开发了一套用于跟踪和监控货物的设备,可以用于生鲜食品、药品储存或冷链运输等应用。 这款尺寸为 121 x 61 x 8 mm 的 “Aovx G系列” 跟踪器集成了多个传感器,包括一个 3 轴加速度计、光传感器以及温度和湿度传感器,用于监控储存或运输中货物的移动、振动状态、篡改、延迟、温度和湿度。 Nordic集成式nRF9160 低功耗 SiP集成了 LTE-M/NB-IoT 调制解调器和 GNSS,尺
[手机便携]
Nordic助力蜂窝IoT跟踪设备监控<font color='red'>存储</font>或运输中的货物
小广播
最新网络通信文章
换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved