位置:51电子网 » 技术资料 » 接口电路

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

发布时间:2008/5/26 0:00:00 访问次数:560

        

    

    

    来源:电子产品世界 作者:张瑞瑞 马晨普

    

    摘要: 本文介绍了基于新型独立控制芯片cp2200的以太网通讯接口的软硬件设计方法。

    

    关键词: cp2200;以太网;c8051f040-p.htm" target="_blank" title="c8051f040货源和pdf资料">c8051f040;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-p.htm" target="_blank" title="c8051f040货源和pdf资料">c8051f040的事件队列是否有事件。一旦事件队列非空,则读取事件标志字,判断事件类型,而后调用对应事件处理子程序。处理子程序执行完毕后,仍然返回到事件循环体中。事件标志字由中断直接或者间接驱动,当某个事件发生后,只需在中断服务程序中将状态字的对应位置位。中断不断向事件队列中添加事件,c8051f040-p.htm" target="_blank" tit

        

    

    

    来源:电子产品世界 作者:张瑞瑞 马晨普

    

    摘要: 本文介绍了基于新型独立控制芯片cp2200的以太网通讯接口的软硬件设计方法。

    

    关键词: cp2200;以太网;c8051f040-p.htm" target="_blank" title="c8051f040货源和pdf资料">c8051f040;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-p.htm" target="_blank" title="c8051f040货源和pdf资料">c8051f040的事件队列是否有事件。一旦事件队列非空,则读取事件标志字,判断事件类型,而后调用对应事件处理子程序。处理子程序执行完毕后,仍然返回到事件循环体中。事件标志字由中断直接或者间接驱动,当某个事件发生后,只需在中断服务程序中将状态字的对应位置位。中断不断向事件队列中添加事件,c8051f040-p.htm" target="_blank" tit

相关IC型号

热门点击

 

推荐技术资料

耳机放大器
    为了在听音乐时不影响家人,我萌生了做一台耳机放大器的想... [详细]
版权所有:51dzw.COM
深圳服务热线:13751165337  13692101218
粤ICP备09112631号-6(miitbeian.gov.cn)
公网安备44030402000607
深圳市碧威特网络技术有限公司
付款方式


 复制成功!