基于LabVIEW FPGA模块的FIFO深度设定实现
用DMA FIFO作为主控计算机与FPGA之间的缓存。它的存储空间包括两部分:一是主控计算机部分,主控计算机开辟一块内存作为FIFO缓存;二是FPGA部分,FIFO占用部分Block Memory资源作为缓存。二者共同组成一个完整的FIFO,通过PXIe总线传递数据。FIFO的传输机制是:主控计算机首先把一个数组的数据存入作为FIFO缓存的内存中;DMA控制器会自动查询FPGA上的FIFO剩余空间,当满足缓存剩余空间大于数据块容量的条件时,控制器通过PXIe总线把整个数据块一并送入FPGA上的FIFO中;FPGA FIFO再将数据顺序送出。
若在主控计算机向FIFO两次写入数据的间隔期间,FIFO中的数据保持不被读空,就能保证输出FPGA的数据是连续的。而合适的FIFO深度是FIFO不被读空的基础,所以确定FIFO深度的设定方法是数据在不同时钟域之间实现连续传输的关键。
3 FIFO深度的设定方法
3.1 FPGA FIFO深度的设定
DMA控制器将数据从主控计算机内存整块的传送到FPGA的FIFO缓存中,所以FIFO的深度要大于数据块的大小。LabVIEW FPGA里块存储FIFO是以2 KB大小来应用的。DMA FIFO使用RIO设备可获取的内置RAM来存储数据信息,该存储空间与内存读/写是共享的。所以要留一部分RAM空间进行内存的读/写,FIFO的最大值为RAM容量减去16 KB。PXIe-5641R的RAM的容量是1 098 KB,所以,FPGAFIFO的深度设定范围为2~1 082 KB。
另一方面,实际上LabVIEW为了能使FPGA高效运行,对Block Memory方式FIFO的大小作了规定,其大小只能为2M-1(数据由FPGA传向主控计算机)或2M+5(数据由主控计算机传向FPGA),M为数据的地址宽度;当设定值不是这些标准值时,LabVIEW会自动的放大到距其最近的一个标准值。这样就确定了FPGAFIFO的深度,但是还不能保证数据能够连续输出。
3.2 主控计算机FIFO深度的设定
由于对主控计算机内存部分FIFO的读/写是以数组形式断续进行的。所以,数组的长度和两次写入的间隔时间是能否保证数据连续性的重要参数,同时考虑到数据输出FPGA是连续且频率固定的。根据FIFO不读空的原则推测:当写入内存的数组的长度N与数据写入内存的时间T和数据输出FPGA的频率F之间满足如下的关系时,就能做到数据的连续传输:
N/T>F (1)
鉴于主控计算机操作系统的非实时性,需要将主控计算机FIFO深度D的大小设定为N的若干倍;通过大量实验并与NI工程师讨论,确定当FIFO的深度D的大小为N的3~5倍时,可完全满足数据连续传输的要求。
3.3 实验验证
数据写入内存的时间与主控计算机运行速度以及数组的大小有关。表1所示的是数组长度和写入内存的时间与输出数据连续性之间关系的实验结果。其中,平均写入内存时间指的是同一个数组循环执行写入操作10万次得到的平均结果。输出FPGA的速率为10 MHz。
当数组长度较小时,单位时间内写入到内存中的数据较少,内存里的数据不能满足FPGA FIFO读取数据的需求,在下一组数据到达之前内存里的数据已经读空,故输出的数据不能连续。当数组长度增大之后,单位时间写入到内存的数据量也随之增大,内存里的数据能够满足FP-GA FIFO读取数据的需求,在内存读空之前把下一组数据送入了内存,所以输出的数据能够保持连续性。实验结果验证了上述推测公式的正确性。
4 数据连续传输的LabVIEW实现
在本文中系统软件包括两部分:Host vi和FPGAvi,二者是独立而又有联系的两个部分。Host vi运行于主控计算机上,FPGA vi运行于FPGA上,二者通过FIFO来传输数据。
4.1 FPGA程序设计
使用图形化的编程环境LabVIEW FPGA模块来定义FPGA逻辑,除了具有上述的优点以外,LabVIEW作为一种并行结构的编程语言,非常适用于FPGA的并行结构,能够十分方便地实现多线程并行任务。
当FPGA vi开始运行时,从Host vi读取数据的FIFO需要一定的初始化时间,时间长度与FIFO的深度成正比。在初始化期间FIFO输出一系列的无效默认值。为了不让无效值进入到下一级的运算中,在DMA方式的FIFO之前加了一个FIFO函数——Get Number of Element to Read,该函数用于获得FIFO内有效数据的数量。当有效数据的数量大于0时,再开始进行下一级运算。考虑到FPGA有限的硬件资源和FPGA FIFO最小值的限制,将数据的地址宽度设为M=11,根据上文分析DMA FIFO的深度设为2M+5=2 053 KB。
4.2 主控计算机程序设计
Host vi是系统程序的另一部分部分,它具有建立硬件对象(FPGA)、与硬件通信和图形显示等功能。主控计算机程序图如图6所示,首先要建立与之进行通信的硬件对象,即FPGA;其次配置系统时钟、输出模式;再次创建FIFO,设置其在主控计算机部分的FIFO深度;然后从电子表格
- 基于LabVIEW RT的自定义流程测控系统(10-30)
- 基于LabVIEW的语音分析平台的实现(10-30)
- 基于示波器卡和LabVIEW的马达编码器测试系统(11-06)
- 基于虚拟仪器的网络虚拟实验室构建(11-06)
- 运用LabView控制DS3900串口通信模块(02-02)
- 采用模块化仪器,对新兴音频和视频应用进行测试(02-19)