欢迎来到天天文库
浏览记录
ID:11198170
大小:122.00 KB
页数:5页
时间:2018-07-10
《基于c6000 dsp ndk的组播网络设计与实现》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、基于C6000DSPNDK的组播网络设计与实现时间:2013-06-1512:58:56来源:电子科技作者:董博宇,毛晓丹,刘志哲,张伟峰,王平摘要:随着系统应用的复杂化,很多情况下需要将相同数据分发至不同的使用终端,这也促进了网络传输组播模式的应用。基于实际应用需求,以TMS320C6455芯片为核心处理平台,利用TI公司DSPC6000平台上的NDK(NetDeveloper’sKit)开发包,对Marvell公司的88E6060(SWITCH)芯片进行配置,实现了适用于多个终端进行组播方式网络通信的嵌入式系统设计。经过测试验证,该系统工作正
2、常稳定,实现了百兆组播传输功能。关键词:C6000;88E6060;嵌入式系统;NDK;组播网络0引言 嵌入式系统采用以太网接口传输数据相对于传统的串口、并口、1553B总线接口来说具有通用性强、传输速度快的特点,并且保证了较高的可靠性。TI公司在TMS320C6455(以下简称C6000系列高端的芯片中,大多提供了网络接口模块,DSP6455)就是其中典型的一款芯片。它的工作时钟可达1GHz,片上集成以太网接口模块EMAC。结合TI公司推出的NDK(NetDevelopKit)网络资源开发包,可以大大缩短嵌入式系统中网络应用的开发周期,并且
3、性能不逊于W5300等专业网口芯片。由于一片DSP6455只有一个EMAC接口以及MDIO管理模块,并且NDK的软件初始化只查询一个PHY口就停止,所以传统应用中,典型设计是在该DSP芯片外部接一个PHY芯片,连接一个终端设备,或者通过总线直接连接以太网专用芯片来实现点对点的网络连接。而现在越来越多的嵌入式系统应用需要连接多个终端设备进行组网,在网络中进行数据交换。本文选择利用DSP6455外接Marvell公司的SWITCH芯片(88E6060),该芯片具备6个端口,每个端口都具备100M/10M全双工的通信能力,最终实现该嵌入式系统与其他两个
4、设备的100MHz组播方式的网络通信。1电路原理设计 基于TIDSP6455的片内EMAC/MDIO模块、片外SWITCH(88E6060)芯片及其外围电路的接口设计,可以快速实现OSI七层模型中数据链路层和物理层(MAC+PHY)的组建。DSP6455支持三种接口连接方式,MII/RMII/GMII。MII接口(MediaIndependentIntetface)以及RMII(ReducedMediaIndependentInterface)接口分别为媒体独立接口和缩减媒体独立接口,它们支持10M/100M工作模式。GMII接口的全称是吉比
5、特媒体独立接口(GigabilMediaIndependentInterface),它支持10M/100M/1000M三种工作模式。因为选取的88E6060只支持百兆MII/RMII的接口方式,本设计采用MII的接口方式进行连接,信号连接框图如图1所示。 设计过程中,使用88E6060的port5作为MII接口与DSP6455的EMAC接口进行连接,port0~port4可以任意使用,作为PHY对外进行连接。本设计以应用port0和port1为例进行说明,其他情况相似。配置时将88E6060的ENABLE_MII5和DISABLE_MII4管
6、脚悬空,通过其内部上拉/下拉使能port5的MII口,DSP6455通过MDIO接口对88E6060的内部PHY寄存器进行访问,通过EMAC接口发送和接收网络数据。2NDK的配置与使用 TI公司的NDK(NetDevelopKit)开发包是基于DSP/BIOS进行工作的,开发包已经集成网络开发所需函数,行使OSI七层模型中传输层、网络层和数据链路层的功能,并按网络开发所需将中断和任务进行配置。当NDK开发环境配置好之后,就可以利用传输语句进行数据的发送和接收。传统情况下,NDK只适用于对单一的PHY进行配置连接,一旦连接建立便中止查询其他的P
7、HY是否可用。本例由于DSP6455外接一片SWITCH芯片,理论上可以将所有能使用的PHY进行初始化并建立连接,所以需要对原有的工作流程进行改造,工作流程对比如图2所示。 改造后的NDK运行流程最重要的是实现对其他外部有效PHY的配置。配置过程需要添加MDIO控制函数来对PHY进行初始化操作。本文使用的PHY为SWITCH芯片的PHY0与PHY1口,所以需要添加对两个使用口进行初始化的语句,来完成对SWITCH芯片的配置工作,初始化代码如下: MDIO_phyRegWrite(0,0x0,0x1100); MDIO_phyRegWr
8、ite(1,0x0,0x1100); 在MDIO_phyRegWrite(uintphyIdx,uintphyReg,Uint16d
此文档下载收益归作者所有