一种精简可靠的低成本嵌入式以太网接口设计

发布者:BlissfulJoy最新更新时间:2006-12-25 来源: 电子产品世界关键字:控制器  成本  开发 手机看文章 扫描二维码
随时随地手机看文章

引言

  当前,嵌入式设计人员在为远程控制或监控设备提供以太网接入时,使用的以太网控制器都是专为个人计算机系统设计的,如RTL8019,DM9008,CS8900A 等。这些器件不仅接口电路复杂、体积较大,而且比较昂贵。CP2200 是Silabs于近期推出的一款独立以太网控制器,它符合IEEE 802.3协议,支持10M以太网接入,而且仅需要很少的外部电路连线就可满足绝大多数嵌入式以太网接口的设计要求,使得潜入式以太网接口的设计大大简化,占板空间大大减小,系统开发成本大大降低。
另外,该以太网控制器具有8位并行主机接口,可以为绝大多数微控制器或主处理器提供以太网通信功能。8位并行总线接口支持Intel和Motorola总线方式,可以使用复用或非复用方式寻址。这些功能加上相关处理器的TCP/IP协议栈,使得嵌入式应用系统的以太网接口实现变得极其简易。

硬件电路设计

  系统的硬件电路示于图1。CP2200的外围电路比较简单。

           图1 硬件电路

I/O并行接口

  CP2200的并行主机接口,支持Motorola 和 Intel两种总线方式,且支持地址数据复用和非复用方式。可以通过将MUXEN和MOTEN引脚接地或拉高电平来实现对主机接口总线方式的配置。

以太网变压器

  要实现以太网接口,以太网变压器是不可缺少的。在差分接收引脚(RX+/RX-)上,需要一个专用于10BASE-T 操作的1:1 脉冲变压器。 在差分发送引脚(TX+/TX-)上,需要外接一个带有中心抽头的1:2.5 脉冲变压器。变压器应具有2kV 以上的电压隔离性能,以防止静电干扰。发送端需要两个8W(精度为1%)的电阻和一个560pF 的电容与特定端相连,接收端需要一个100W电阻与特定端相连。

  按照CP2200的要求,笔者采用的是PRJ系列的PRJ-010型变压器。该变压器集成了RJ-45接头,在省去了不少连线的同时也提高了高频信号传输的可靠性。

其他电路

  LINK和ACT引脚输出电平来驱动LED,用来指示网络的连接和活动状态。

  所有电源引脚都必须与同一个外部3.3V 电源相连。类似的,所有参考地都应在外部连接到相同的接地点。每个VDD 和VSS 引脚都应连接一个0.1mF 的陶瓷旁路电容,该电容尽可能靠近引脚。

  需要特别说明的是,驱动双绞线接口需要相对高的电流,因此以太网的收发数据线应尽可能短,并且线径适当加大以减少电阻损耗(为了保证数据的可靠传输,笔者的PCB电路板选择了20mil的线径)。

软件设计

  TCP/IP 协议种类繁多,相互之间交互作用复杂,在单片机上不可能实现所有协议,所以必须对协议栈进行剪裁。结合系统的具体通信要求,笔者的系统最后只保留了TCP、UDP、IP、ICMP、ARP协议模块。在协议栈程序的整体设计上,考虑到单片机的单任务执行方式很难发挥TCP/IP协议的特点,我们采用了基于事件驱动机制的TCP/IP协议栈的实现方法。该机制的引入,使得系统在保证具有高效的汇编语言代码效率的同时,实时响应性也得到了大幅提高。下面将具体阐述事件驱动机制的特点和基于该机制的TCP/IP协议栈的实现。

事件驱动机制

  系统初始化完成后, 进入事件循环体,不断查询C8051F040的事件队列是否有事件。一旦事件队列非空,则读取事件标志字,判断事件类型,而后调用对应事件处理子程序。处理子程序执行完毕后,仍然返回到事件循环体中。事件标志字由中断直接或者间接驱动,当某个事件发生后,只需在中断服务程序中将状态字的对应位置位。中断不断向事件队列中添加事件,C8051F040处理程序则不停地从事件队列中读取事件标志字,处理事件。

事件驱动机制的特点为:

  *由于在中断处理程序中,仅仅执行了改变事件标志字这样的简单程序语句,把事件添加到C8051F040的事件队列中后就立即返回。所以系统关闭中断的时间很短。增强了系统对中断处理的实时性。

  *C8051F040根据当前读取的事件,进行相应事件处理或者向事件队列中添加进一步处理所需的事件。这实际上是把任务都进行了分步处理,在执行一步这一任务的同时,也可以执行一步其他任务。这样.在不影响主程序流程的情况下,又提高了系统的实时性。

事件循环的简要流程

  图注:1=EVENT_ETH_ARRIVED;2=EVENT_TCP_RETRAN;3=EVENT_TCP_INACTIVITY;4=EVENT_ARP_RETRAN;5=EVENT_AGE_ARP_CACHE;6=EVENT_COME_NEWDATA;
  图2  事件循环流程

  事件循环体的简要流程如图2所示,其中各事件的含义分别为:

  EVENT_ETH_ARRIVED: 有待处理的以太网帧事件。检测到此事件,C8051F040会调用读CP2200接受缓冲区程序,然后对帧进行解包处理;

  EVENT_TCP_RETRAN: TCP重传事件。当TCP定时器超时,触发该事件;

  EVENT_TCP_INACTIVITY:关断不活动连接事件。当某连接超过0.5秒没有收发数据,则触发此事件;
EVENT_ARP_RETRAN:ARP请求数据包重传事件。当某一ARP请求在发出0.5秒后没有相应,则触发该事件。经两次重发都没回应,则将以该IP为目的地址的数据包丢弃;

  EVENT_AGE_ARP_CACHE:更新ARP缓存事件。每60秒触发该事件一次;

  EVENT_COME_NEWDATA: 有新数据事件。当有新数据待发送时,触发该事件;

结语

  CP2200的多种集成功能如CRC校验,数据滤波等有效地减轻了单片机的载荷,它内部的收发接口单元操作起来灵活方便,为以太网数据包提供了有效的缓冲。芯片具有稳定的工作性能和抗干扰抗震性能,笔者利用CP2200, C8051F040单片机和TCP/IP协议栈开发出了用于铁路机车的以太网通讯接口板卡。此板卡已在测试机车上运行,工作性能良好,能够进行稳定的数据传递。

参考文献:
1. Silicon Laboratories Inc. CP2200 datasheet. http://www.silabs.com/
2. Silicon Semiconductor Inc. c8051f040 datasheet. http://www.silabs.com/
3. Special Edition Using TCP/IP,Ramadas Shanmugam ,R.Padmini,S.Nivedita 尹浩琼 李剑译 电子工业出版社
4. 《TCP/IP祥解 卷2 实现》W.Richard Stevens http://www.china.pub.com/

关键字:控制器  成本  开发 引用地址:一种精简可靠的低成本嵌入式以太网接口设计

上一篇:基于ASIC FPGA的IPv6路由器PoS接口设计
下一篇:一种基于PCI IP核的码流接收卡的设计

推荐阅读最新更新时间:2024-05-13 18:16

挪威科技大学开发新型电解质 用于制造更好的锂离子电池
现在,电动汽车迅猛发展,对锂离子电池的需求也越来越高。据外媒报道,挪威科技大学(NTNU)的研究人员探讨使用不同的材料来制造关键部件,以提高电池的能量密度,延长电动汽车的续航里程。 (图片来源:挪威科技大学) 用硅代替石墨 电池由阴极(带正电)、阳极(带负电)和电解质液体组成,在两个电极之通过电解质液体移动带电粒子,可以提供电力。在锂离子电池中,当电池充电时,锂离子从阴极移动到阳极,并储存在阳极中。当电池放电时,离子移动回阴极,从而产生电流。 现在,大多数锂离子电池都使用石墨阳极。然而,用硅代替石墨有望大幅提高能量密度。NTNU材料科学和工程系Ann Mari Svensson教授表示:“在锂离子电池中,用户
[汽车电子]
挪威科技大学<font color='red'>开发</font>新型电解质 用于制造更好的锂离子电池
ARM芯片基于linux嵌入式操作系统实现的CMU控制器方案
zigbee无线通信与linux嵌入式操作系统是电子人都经常接触的,在这里我们设计了一种以ARM芯片S3C2440为硬件平台,基于linux嵌入式操作系统所实现的CMU控制器。通过zigbee无线通信协议将CMU与各个家电无线节点和传感器节点相连,并通过无线路由器连接以太网实现远程控制的智能家居网络系统。在硬件芯片选择和电路设计方面优化了系统的结构,大大降低了系统的成本,改善了系统的性能。 伴随着数字化、网络化的进程。智能化的浪潮席卷了世界的每个角落,成为势不可挡的历史趋势,在这种形式下智能网络家居技术应运而生,它依靠3C技术(Computer TechnologyCommunication Technology Contro
[单片机]
ARM芯片基于linux嵌入式操作系统实现的CMU<font color='red'>控制器</font>方案
双镜头相机模组成本增4倍之多,模组厂商们的春天来了!
集微网消息,毋庸置疑,双摄像头俨然已成为智能手机高端机型的标配,最新消息显示,预计下半年推出的三星 Galaxy Note 8 可能也采用双镜头与苹果 iPhone 8 相抗衡。摄像头的增加,不仅提升了拍照性能,更能帮助模组厂商带来新的盈利空间,据悉,双镜头相机模组价格约是智能手机常规相机模组的4倍多。 据研究机构预测,到2018年双摄产业链市场规模预计超过87.3亿元。受益于此,大立光、舜宇光学、欧菲光、信利、丘钛等双镜头模组厂商,索尼、三星、海力士等 CMOS 图像传感器厂商,以及虹软、LinX 等算法公司都将迎来快速发展。 此前,凯基投顾分析师郭明錤发布报告称,今年下半年即将发布的 iPhone 8 将配备前置3D相机模组,
[手机便携]
苹果watchOS 8.6开发者预览版Beta 3发布
苹果今日向 Apple Watch 用户推送了 watchOS 8.6 开发者预览版 Beta 3 更新(内部版本号:19T5562f),本次更新距离上次发布隔了 7 天。   若要安装更新,请确保 Apple Watch: 正在充电 在已接入无线局域网的 iPhone 通信范围内   Apple Watch 至少充电 50% 时将开始安装。更新完成前请勿重新启动 Apple Watch 或将之从充电器上移开。
[手机便携]
苹果watchOS 8.6<font color='red'>开发</font>者预览版Beta 3发布
欧宝开发新技术 根据司机视线控制前大灯
欧宝近日宣布,该公司正与德国达姆施塔特工业大学(TechnicalUniversityofDarmstadt)合作研发采用最新眼球追踪技术的第三代汽车自适应大灯系统,该系统可以根据驾驶员视线的改变来控制灯光方向和强度。 新一代高性能眼球追踪自适应大灯要求汽车至少配备5至10颗摄​​像头。起初,研究人员使用网络摄像头对驾驶员头部的突出位置(如鼻子和眼睛)进行扫描,以检测驾驶员视线的变化。 网络摄像头将收集的信息转换成数据指令并推送至电子控制执行器(electronically-controlled actuators)及前大灯投影。不过由于数据计算时间太长以及摄像头记录速度太慢,该摄像头难以适应不同路况的要求
[汽车电子]
欧宝<font color='red'>开发</font>新技术 根据司机视线控制前大灯
曝三星联合AMD开发Exynos SoC:或年内亮相
2月26日消息,早在2019年,三星就与AMD正式达成多年期战略合作,双方将在超低功耗、图像处理等领域求得更多的发展。   近日,有消息指出,三星将于今年6月推出基于ARM芯片的新一代Exynos SoC,并将借此打造一款基于ARM架构的Windows 10笔记本电脑。   据了解,目前适用于Windows 10 ARM平台的芯片只有高通一家,而其他能够为PC设计ARM芯片的芯片厂商只有苹果,目前苹果已经逐步从英特尔处理器过渡到自家Apple Silicon芯片上。   此次,三星推出基于ARM架构的笔记本电脑旨在与高通骁龙8cx竞争。   据悉,三星曾发布过基于ARM平台的Windows 10电脑,例如Galaxy B
[手机便携]
曝三星联合AMD<font color='red'>开发</font>Exynos SoC:或年内亮相
FPGA开发套件加速全高清HDR摄像机设计
      为了向摄像机生产商提供高质量的HDR摄像机参考设计,帮助其快速开始基于FPGA的高清摄像机设计开发,莱迪思半导体(Lattice)日前发布了其最新的HDR-60摄像机开发套件。这是一款基于LatticeECP3 FPGA系列可量产的高清摄像机开发系统,预载入了莱迪思合作伙伴Helion GmbH带有即插即用的评估版图像信号处理(ISP)流水线的IP核。该IP核可实现每秒60帧的1080p,并带有2D降噪和高动态范围(HDR)。   Lattice负责市场业务的副总裁Douglas Hunter表示,HDR-60套件的价值就在于“实现了最低系统材料成本的同时,还满足了原有的系统基础结构并保障了客户的投资”。据悉,该开
[嵌入式]
教你手上没有开发板如何跑RT-THREAD STM32应用
首先打开 RT-Thread Studio,新建RT-Thread 项目: 目前支持 QEMU 模拟仿真的开发板有这些: 大家可以看到,其中包含了 GD32VF103、VEXPRESS-A9、STM32F4 系列的一些开发板 我们以 STM32F401 为例,新建项目后这样配置,注意系列一定要选对,要是上面支持 QEMU 模拟仿真的开发板系列,否则没有对应的 QEMU 调试器: 如果没有的话,就选择 “添加更多” 然后下载: STM32F4 的芯片支持包在这里: 点击后,再点击页面下方的 “安装资源包”即可安装。 创建后我们得到这样一个工程: 查看 main.c 代码如下: 我们首先点击菜单栏的编译构建
[单片机]
教你手上没有<font color='red'>开发</font>板如何跑RT-THREAD STM32应用
小广播
最新应用文章
换一换 更多 相关热搜器件

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 安防电子 医疗电子 工业控制

词云: 1 2 3 4 5 6 7 8 9 10

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved