基于usb3.0和fpga的多串口传输系统设计

基于usb3.0和fpga的多串口传输系统设计

ID:30830007

大小:107.99 KB

页数:7页

时间:2019-01-03

基于usb3.0和fpga的多串口传输系统设计_第1页
基于usb3.0和fpga的多串口传输系统设计_第2页
基于usb3.0和fpga的多串口传输系统设计_第3页
基于usb3.0和fpga的多串口传输系统设计_第4页
基于usb3.0和fpga的多串口传输系统设计_第5页
资源描述:

《基于usb3.0和fpga的多串口传输系统设计》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、基于USB3.0和FPGA的多串口传输系统设计多串口数据通信技术主要研究数据的多串口采集、存储和处理。由于串口通信技术的广泛应用,使得多串口采集卡一直是研究的热点,从早期的基于PCI总线的多串口数据采集卡到后来的基于USB的多串口数据采集卡,以及现在的基于USB3.0的多串口数据采集卡。PCI采集卡由于使用不方便,逐渐被淘汰,目前USB传输系统被广泛应用。USB2.0理论传输速度为480Mb/s,而USB3.0的传输速率可高达5Gb/s,且在USB2.0的基础上又增加了超高速传输模式。本文设计的系统中有80个485传输通道,每个通道的速率为1~10Mb/s,最高传输速率可达8

2、00Mb/s,USB2.0已不能满足此要求。因此本文采用了Cypress的CYUSB3014和Altera的CycloneIII系列FPGA,CYUSB3014保证与PC的传输性能,FPGA负责多串口数据的采集以及对CYUSB3014的控制。1EZ-USB3.0FX3与FPGA接口设计1.1系统框架整个多串口数据采集与传输系统框图如图1所示。图中虚线部分为该系统的硬件框图,整个系统由3部分组成,USB3.0芯片选择了业界性能表现最好的Cypress的CYUSB3014芯片(简称FX3芯片),理论上通信速率可达4.8Gb/s,该芯片除了拥有GPIF2.0接口可方便与外设进行通信

3、外,还有标准的SPI、UART、I2C、I2S与外设进行通信;FPGA采用了Cyclone3C40系列的芯片,逻辑资源、片上RAM以及I/O脚数目都能充分满足本系统设计;80路485传输芯片采用了ADI的ADM3485E,是一款3.3V低功耗数据收发器,提供±15kV的ESD保护,适用于多点总线线路的半双工通信。共模输入范围-7V~+12V,数据速率可达12Mb/s,能满足本系统的设计要求。图1多串口数据传输系统框图1.2FX3与FPGA的通信设计FX3与FPGA通信主要分为两类:(1)FX3对FPGA的配置信息:PC通过FX3将串口的相关信息发送给FPGA,如各串口的奇偶校

4、验、波特率、空闲位、每路的统计信息等配置,此类信息数据量比较小;(2)FX3与FPGA的大容量数据通信:FPGA将485采集的数据通过FX3传输到PC.为了有效地利用FX3的超高速数据传输特性,针对这两种不同的数据类型,本设计将两种数据通道分开设计,其中配置信息较少,而采集的485数据容量很大,为了不使配置信息数据打断485数据通道,将配置信息和数据信息通过两个独立的通道进行传输,其中配置信息采用了通过FX3的UART和FPGA进行通信,通信格式如下:①EZ-USB向FPGA发送命令格式②FPGA返回命令格式FX3每发一条配置参数给FPGA,FPGA都会返回相应配置回应,并通

5、知FX3可以继续发送下一条配置信息,在配置信息都发送完成后,FX3最后会发送一条配置完成命令,此时FPGA会启动外围接口电路进入正常的数据采集过程。2USB3.0芯片固件设计Cypress公司为USB3.0芯片提供了一个开发包,其中包括了典型的固件代码。对USB3.0芯片固件的设计,可利用EZ-USBFX3固件函数库简化加速USB3.0固件程序的开发。固件程序主要完成的工作有:初始化、处理标准的USB设备请求及USB挂起时的电源管理等。任务循环的流程图如图2所示。 图2任务循环流程图3FPGA逻辑设计FPGA采用了Altera公司的CycloneIII系列的3C40-C8,其

6、逻辑门数有200万门左右,最高工作频率可以达到300MHz.整个工程使用了Verilog语言编写,整个工程的综合、布局布线都是在Quartus11.0版本下进行,仿真软件使用Modelsim6.5se版本。本设计中FPGA逻辑设计主要包括485数据采集模块及与FX3的读写时序控制逻辑,整个工程使用逻辑单元,片上RAM使用率接近系统的95%,整个系统工作频率为100MHz.3.1逻辑模块设计系统的逻辑模块分为时钟模块、FX3发送/接收缓存模块、发送/接收控制模块、FX3读写控制模块、485接收模块、485发送模块以及配置串口参数模块。整个系统的数据流分为两个过程:485数据采集

7、过程和485发送控制命令过程。(1)485数据采集过程:485数据通过485接收模块传送给FX3接收缓存模块,在FX3数据接口没有被占用时,通过FX3读写控制模块发送给USB3.0芯片并传到PC端。(2)485数据发送过程:USB3.0芯片通过FX3读写控制模块将数据发送到FX3发送缓存模块中,在收发控制模块检测到相关串口空闲后通过485发送模块将相关数据发送出去。485收发相对于USB3.0速度来说,属于慢速设备。为了提高USB3.0总线利用率,此处只设计了两种缓存,即接收缓存和发送缓存,大小都设置为

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。