当前位置:首页 > 嵌入式 > 嵌入式硬件

摘要: 本文介绍了基于新型独立控制芯片CP2200的以太网通讯接口的软硬件设计方法。
关键词: CP2200;以太网;C8051F040;TCP/IP" target="_blank">TCP/IP

引言

当前,嵌入式设计人员在为远程控制或监控设备提供以太网接入时,使用的以太网控制器都是专为个人计算机系统设计的,如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:///
2. Silicon Semiconductor Inc. c8051f040 datasheet. http:///
3. Special Edition Using TCP/IP,Ramadas Shanmugam ,R.Padmini,S.Nivedita 尹浩琼 李剑译 电子工业出版社
4. 《TCP/IP祥解 卷2 实现》W.Richard Stevens http:///

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭