电子工程师的网站
首 页 |  新闻资讯 | 最新产品 | 解决方案 | 技术参数
设计应用
电路图 | 技术资料 | 芯片资料 | 技术论坛
  现在位置: 首页 > 设计应用 > 嵌入式系统/ARM技术 > 详细信息
嵌入式系统/ARM技术:一种低成本的Ehternet嵌入式系统的设计
来源:   时间: 2007-10-29 1:02:09    
  摘要:介绍了种廉价的can与以太网互连的方案。该方案实现了以太网与现有can总线的直接连接。方便了管理监控层(以太网)与生产测控层(can总线)之间的信息交流。详细介绍了硬件设计原理,给出了软件设计步骤和主要流程图。 
  关键词:can总线 以太网 rtl8019as芯片 单片机 tcp/ip协议
  随着互联网中硬件的迅猛发展,网络用户呈指数增长。在使用计算机进行网络互联的同时,各种家电设备、仪器仪表以及工业生产中的数据采集与控制设备也逐步地走向网络化,以便共享网络中庞大的信息资源。
本设计是以全电子化铁路车站控制系统为背景,任务是实现铁路车站执行机与远程监测机之间的信息交换。其中,执行机包括各个执行单元,采用can总线接口。监测机为远程的pc控制机,采用以太网接口。本设计指在实现can通信链路和以太网通信链路的透明连接,最终形成通用的can总线以太网网关。
can总线与以太网通信,通常采用两种方案,一种是采用工控机加网卡来实现。这种连接方式成本高,开发周期长。另一种是采用32位mcu+rtos的方案,这种方案采用32位高档单片机,在rtos(实时多任务操作系统)的平台上进行软件开发,在嵌入式系统中实现tcp/ip的协议处理。它的缺点是:单片机价格较高,开发周期较长,需要购买昂贵的rtos开发软件,对开发人员的开发能力要求较高。鉴于上述方案的优缺点,笔者设计一种单独的以太网网关互连系统,成功地实现了以太网与can总线的直接互联。
1 硬件设计
  系统电路原理如图1所示。本系统以单片机为界,为了两部分:can总线控制部分和以太网控制部分。系统提供rj45接口连接ethernet网络,并且提供一个can总线接口供用户使用。系统可以把从ethernet上过来的ip数据报解包送给can总线接口,也可把从can总线接口过来的数据封装为ip包送到局域网中。
1.1 单片机及其外部存储器
  单片机w78e58b为主要控制部分,实现对网络芯片和can控制器的控制。在微处理器内嵌入tcp/ip协议和can协议,完成两者之间的协议转换,实现can接口和以太网接口之间数据的透明传输。
62256是32k的外部ram,用来缓存以太网数据包和can总线传来的数据,使用它的目的是提高单片机的数据传输速度和处理复杂的tcp/ip协议。由于以太网最大的数据包有1514字节,而单片机w78e58b只能256字节的ram,无法存储这么大的数据包,只能放在外部ram里,以使单片机能够高速地吞吐数据。p2.7为低电平时,62256被选通,因此其寻址范围为0000h~7fffh。
  单片机w78e58b内部有32k的eeprom,可用来存储一些配置信息,如网关ip地址、mac地址、sja1000的id网络标识符、网络掩码和总线定时(btr0、btr1)等。这样可以灵活方便地修改网关参数,适应不同的环境,同时也有利于以后的扩展。
1.2 以太网控制部分
  rtl8019as是台湾realtek公司制造的一种高集成度的全双工10m/s以太网控制芯片,可实现基于ethernet协议的mac层的全部功能,内置16kb的sram、双dma通道和fifo,可完成数据包的接收和发送功能。
在该设计中,rtl8019as使用跳线模式(jp置为高),数据线使用八位模式(iocs16b用27kω电阻下拉接地),rtl8019as的低五位地址线sa0~sa4对应接到单片机的p2.0~p2.4,sa6和sa9接vcc,其它地址线全部接地。当p2.6和p2.7同时为高电平时rtl8019as的片选信号aen使能。rtl8019as的i/o地址需要映射为单片机的i/o地址,这样单片机才能操作rtl8019as。根据电路设计,该系统中单片机的i/o地址与rtl8019as的i/o地址之间的映射关系为:0xc000h~240h,0xc100h~241h…)xdf00h~25fh,共32个字节。rtl8019as除与单片机连接外,还将其网络收发器的四根引脚hd、ld、trin+、tpin-通过外部的隔离滤波器lpf与以太网相连,目的是提高网络通信的抗干扰能力。
1.3 can总线控制部分
  sja1000为can总线控制器,具有多主结构、总线访问优先权、广播报文功能及硬件滤波功能,具有简单总线连接的sja1000可完成物理层和数据链路层的所有功能。它具有两种工作模式basiccan和pelican。basiccan仅支持标准模式(本文仅介绍basiccan模式),支持错误分析功能,对can收发器进行控制,为微控制器提供控制can总线的简单接口。单片机对saj1000的读写就像读写自己的外部ram一样。p2.7取反后作为其片选信号线。因此,sja1000对应地址为8000h~807fh。sja1000的/int引脚接单片机的int1引脚,使单片机能够实时响应can的中断请求。
  tja1050为can收发器,是can协议控制器和物理总线之间的接口,可以对can总线提供差动发送和接收能力。微控制器对can控制器进行相应配置后,收发器自动完成相应的can总线动作。有较强的抗干扰能力,最多节点数可达110个。
采用高速光耦6n137实现sja1000与tja1050之间的电气隔离,保护控制系统电路,以满足在最高速率1m/s下的电气响应。
2 软件设计
  整个系统的软件分为两部分:can控制器协议转换模块和以太网控制器协议转换模块。其程序结构如图2所示。
当以太网应用层有数据要发送到can节点时,首先由以太网控制器协议转换模块从传输层数据报文中解析出完整的can协议数据包,存放在数据缓冲区a中,再通知总调度模块,由它调用can控制器协议模块将can协议数据包发送到can总线上。反过来,当can设备有数据要发送到用户层时,先由can控制器协议转换模块将完整的can协议数据包存放在数据缓冲区b中,再通知总调度模块,由它调用以太网控制器协议转换模块,将完整的can协议数据包作为应用层数据封装起来,再发送到以太网的应用。
2.1 can控制器协议转换模块
  can通信协议有四种不同的帧格式,本系统中使用标准帧格式,其格式如表1所示。can首先接收仲裁域,根据仲裁域的内容判断所接收的信号是哪种帧格式,然后用户将相应的数据写入数据域中进行发送,或从数据域中读取接收到的数据。
表1 帧传送格式
帧起始  仲裁域  控制域   数据域   crc域  应答域  帧结尾 
 sof    id rtr  ide ro  dlc data   crc    ack    end 
can控制器协议转换模块主要由sja1000的寄存器读程序canread()、写程序、canwrite()、初始化程序caninit()、发送程序txdsub()和接收程序rxdsub()组成。
  选用can2.0a协议构建can总线控制网络,对sja1000的初始化主要包括对控制寄存器cr、验收代码寄存器acr、验收屏蔽寄存器amr、总线定时寄存器btr0/1和输出控制寄存器ocr的设置。初始化完成后,由总调度模块监控sja1000控制器。当can总线上有数据到达时,通过中断方式调用接收子程序rxdsub(),把这一帧数据存入数据缓冲区b中,然后翻译接收缓冲器。同样,当有按can2.0a协议格式组合成的一帧数据报文在数据缓冲区a中要发送到can总线上去时,总调度模块调用can发送子程序txdsub()发送。
2.2 以太网控制器协议转换模块
一个标准的以太网物理传输帧如表2所示(单位:字节)。
表2 以太网的物理传输帧结构表

同步位 分隔位 目的地址 源地址 类型字段 数据段   帧校验序列 
  pr     sd     da      sa      type    data      fcs 
  7      1      6       6        2     46~1500    4 

  除数据段的长度不定外,其它部分的长度都固定不变。以太网规定整个传输包的最大长度不能超过1514字节(14字节为da、sa、type),最小大能小于60字节。除去ds、sa、type14字节外,还必须传输46字节的数据,当数据段的数据不足46字节时需填充,填充字符的个数不包括在长度字段里;超过1500个字节时,需拆成多个帧传送。
以太网控制器协议转换模块主要负责从udp数据包中解析出完整的can协议报文,存入数据缓冲区a中。同时,也可以将数据缓冲区b中的完整can协议报文封装成udp数据报,然后将其发送到以太网上。
主程序工作流程图如图3所示,单片机首先初始化网络设备。网卡ip地址和物理地址存于单片机的eeprom中,单片机复位后首先读取这些数据以初始化网卡。
  网卡初始化完成以后,当有数据从rj45过来时,单片机对数据包进行分析,如果是arp(物理地址解析协议)数据包,则程序转入arp处理程序。如果是ip(网间协议)数据包且传输层使用udp(用户数据报协议),端口正确,则认为数据报正确,数据解包后,送入数据缓冲区a,最后把数据部分通过can接口输出。反之,如果单片机从can接口收到数据,则将数据按照udp协议格式打包,送入数据缓冲区b,由rtl8019as将数据输出到局域网中。
本系统在通信传输层来采udp协议是考虑到can协议数据报为短帧形式(每个数据帧最多为8字节)。如果采用tcp传输协议,要传输8个字节can协议数据,需先通过三次握手建立连接,再传输数据,之后还要通过握手释放连接。这样的传输效率对有限的网络资源来说无疑是一种浪费。而udp是无连接的传输,可以提高网络传输效率,同时也可以减轻网关的处理任务压力。udp传输协议可靠性的不足之处可以采用加传校验机制来改善。通过实验测试,表明这种方法是行之有效的。
本文介绍了种低成本、高可靠性、快捷的嵌入式can总线与以太网互连的软硬件实现方法。该互连方案保证了管理监控层与生产测控层之间的连接,方便了上下层信息交流,适用于现有的网络传输系统,有着广泛的应用前景。特别是在数据采集和数据传输 领域中,可以广泛地应用于嵌入式网络接口功能的设计中。
相关信息
发表评论
打印本页 关闭本页
基于SHARC DSP与SJA1000的CAN总线接口设计
  引言   当前,有一些微处理器将CAN控制器嵌入到系统之中,但是仍有大量人们比较熟悉的微处理器并不带有CAN控制器。采用微处理器和CAN控制器组合的设计成为必要,而且,CAN控制器具有完成CAN总线通信协议所要求的全部必要功能,因此,CAN控制器与其它微处理器的接口设计成为设计CAN总线系统的首要工作。本文重点介绍以SHARC DSP为核心的、基于SJA1000的CAN总线接口设计。   SJA1000...
>>详细内容
基于PNX1500的嵌入多媒体平台
  随着片上系统设计技术的发展,嵌入式技术在IT界扮演着越来越多的重要的角色。多媒体应用是嵌入式系统的一个重要方面,本文介绍了一种基于飞利浦PNX1500DSP的多媒体嵌入式系统的硬件设计以及底层驱动程序。1 平台整体结构图   基于飞利浦的嵌入式多媒体硬件平台以飞利浦PNX1500为核心,完成视音频编码解码工作。由EEPROM存储系统最基本的启动配置程序,如配置内存和DSP工作频率,配置...
>>详细内容
SJA1000控制器在多电机综合保护器中的应用
  1 引言 在矿井下生产作业时,良好通风是保证安全生产的关键。常用的通风设备一局部通风机用于调节井下通风状况,调控瓦斯浓度。风机中的电机和其他电机一样,在运行过程中因为负载、电网及电机本身等因素常出现过载、缺相、短路等故障,影响其正常运行,从而影响矿井的正常通风。为了适应矿井生产需求,综合多方面因素及项目要求,研制一台多电机综合保护器,采用AT89C52单片机对煤矿井...
>>详细内容
基于单片机89C52与CPLD的数字语音存储与回放系统(CY62256)
  本系统以89C52单片机和MAX7000S系列EPM7128SLC84-15的CPLD器件为主控制器,实现将语音信号经脉冲编码调制、增量调制、"插值法"后压缩存储与回放的系统,用户可以通过按键选择录、放音的模式,同时液晶显示屏显示提示信息、录、放音的时间长度信号。 总体设计 系统组成框图如图1所示,主要由语音处理前向通道、A/D转换模块、单片机控制兼数据处理模块、D/A转换模块、键盘显示模块及后...
>>详细内容
MJ15004G的技术参数
  产品型号:MJ15004G类型:PNP集电极-发射集最小雪崩电压VCEO(V):140集电极最大电流IC(Max)(A):20直流电流增益hFE最小值(dB):25直流电流增益hFE最大值(dB):150最小电流增益带宽乘积Ft(MHz):2总功耗PD(W):250封装/温度(℃):TO-204AA/-65~200价格/1片(套):¥21.40
>>详细内容
MJ15003G的技术参数
  产品型号:MJ15003G类型:NPN集电极-发射集最小雪崩电压VCEO(V):140集电极最大电流IC(Max)(A):20直流电流增益hFE最小值(dB):25直流电流增益hFE最大值(dB):150最小电流增益带宽乘积Ft(MHz):2总功耗PD(W):250封装/温度(℃):TO-204AA/-65~200价格/1片(套):¥20.60
>>详细内容
已有(
)位对此新闻感兴趣的网发发表了看法 >>更多评论
内 容:
     
 
热点新闻
一周排行
关于我们 | 服务项目 | 付款方式 | 广告服务 | 联系我们 | 友情链接 | 投诉 建议 合作 | 网站地图 | 加入收藏
Copyright © 2007-2008 WEEQOO.COM Corp.All Rights Reserved. 版权所有 经营许可证编号:浙B2-20050339 法律声明
维库电子旗下网站:维库电子市场网 | ChinaICMart | 维库电子开发网 | 维库电子人才网
总部:杭州市下城区朝晖路182号国都发展大厦1号楼80A
电话:0571-85889139-8007 QQ:303939539 | MSN:zh1226@hotmail.com |  邮箱:laz8258@163.com dzsc51@163.com