IEEE1394总线的网络通信系统设计方案
1 系统方案
IEEE1394高速网络通信系统采用树状拓扑结构来构建网络,通过软件将主控计算机上的1394节点设为根节点,其他设备上的1394节点设为叶节点,目的是使主控计算机能对整个网络进行控制和监管。组建好的网络拓扑结构如图1所示。
图1 高速网络通信系统拓扑结构图
在图1中,根节点与叶节点之间、叶节点与叶节点之间都采用IEEE1394a标准线缆连接。本网络中根节点下有两棵树,它们都在同一条总线Bus0上。不在一棵树上的1394节点也可位于同一个设备上,如Node1、Node2和Node5都在同一个设备上。
2 硬件设计
主控计算机上的1394节点采用PowerPC作为通信和数据处理的核心。采用PowerPC的原因是它的体系结构是开放的,而且PowerPC在大数据量、高速信号处理中具有强大的优势和很好的应用潜力。由于大多数PC机上都具有PCI接口,PCI总线应用广泛,PCI接口驱动的通用性较强,所以主控计算机与PowerPC可通过主控计算机上的PCI接口进行通信,这就简化了在主控计算机上开发PCI接口驱动的工作。而IEEE 1394接口采用双接口芯片设计,并配备了SDRAM作为大容量数据缓冲,用Flash来存放软件。1394节点都是通过1394总线连接的。主控计算机上的1394节点(已设为根节点)通过1394总线与网络中其他某个设备上的1394节点(已设为叶节点)相连的整体框图如图2所示。左侧为根节点架构,右侧为叶节点架构。叶节点的架构与根节点的架构是类似的,但由于只有根节点与主控计算机连接,而叶节点不与主控计算机相连,所以叶节点并不需要PCI总线。
图2 主控计算机上的1394节点架构
IEEE1394接口采用的是链路层芯片TSB12LV32和物理层芯片TSB41AB3。TSB41AB3是支持3个线缆接口的物理层芯片。TSB12LV32是一款支持IEEE1394a总线标准的高性能通用链路层芯片,最高传输速率为400 Mb/s[5],本网络可采100 Mb/s、200 Mb/s、400 Mb/s来进行数据的传输。TSB12LV32为后端提供了主机接口,系统中PowerPC采用主机接口完成寄存器的配置和异步流包的传输。TSB12LV32还为PowerPC提供了中断输出INT和可编程状态STAT[0:2],用于总线复位、传输错误和内部FIFO状态指示。
对于数据的收发,采用DMA来进行数据的搬运而完成。通过中断机制来把收到消息事件报告给核心处理器PowerPC,由处理器对消息进行处理。
图3 软件层次图
3 软件设计
根据软件要实现的功能,可把软件划分为3个层次,如图3所示。
3.1 1394内核软件
对1394内核的物理层和链路层寄存器进行配置,对OHCI、总线管理器配置等[3],并对这些内核函数进行了封装。这种隔离的好处是可使用户不必关心底层硬件,只需调用内核函数就可开发出用户软件。通过建立结构体来将这些函数进行分类、链接,驱动软件在调用内核函数时可通过结构体来直接找到相应的内核函数,从而进行调用,这样就把1394内核软件和上层驱动链接了起来。
3.2 驱动软件
由于1394协议支持异步传输和等时传输,且为了保证传输的可靠性,故采用异步流包进行数据的传输。对于发送,驱动软件先根据异步流包的格式,对通信软件中的消息进行组帧打包,然后调用内核函数进行发送。对于接收,是利用中断机制来接收消息的。
3.3 通信软件
上电后,1394总线上首先会出现持续125 μs左右的总线复位(bus reset)状态,之后进行树标识和自标识工作。树标识进程定义了总线的拓扑结构。树标识之前,每一1394节点都知道自己和其他的节点相连,此过程过后,整个网络的拓扑就形成了,设置计算机为根节点(root),其他的节点为分支节点。树标识后是自标识进程,自标识通过根节点发送自标识授权信号和节点返回自标识数据包来完成,其实现的功能主要有:为每个节点分配物理标识,相邻节点交换传输速度信息,将树标识进程定义的拓扑在整个网络中广播。
根据内核函数,对整个通信网络进行初始化,包括初始化PCI总线init_pci()、初始化1394设备init_1394dev()、树标识和自标识、主控机上的1394节点设为根节点(叶节点不进行此步)、初始化中断等。
初始化完毕后,首先挂接中断服务程序。然后根节点采用发送STOF包来进行网络同步,即以发送STOF包作为一帧的开始
模拟电路 模拟芯片 德州仪器 放大器 ADI 模拟电子 相关文章:
- 12位串行A/D转换器MAX187的应用(10-06)
- AGC中频放大器设计(下)(10-07)
- 低功耗、3V工作电压、精度0.05% 的A/D变换器(10-09)
- PIC16C5X单片机睡眠状态的键唤醒方法(11-16)
- 用简化方法对高可用性系统中的电源进行数字化管理(10-02)
- 利用GM6801实现智能快速充电器设计(11-20)