1 引言
数据存储是数据采集过程中的一个重要环节,目前大部分数据存储系统都是用内置工控机的方法完成数据保存任务,这种方法系统功耗大,硬件成本高,不适用于具有内记功能要求的系统。本系统采用FPGA和DSP直接控制硬盘进行数据存储,并采用一片FIFO 作为数据缓存,设计思路比较新颖,硬件结构简单,成本低,直接控制硬盘的方法可将系统功耗降至最低,具有自动内记功能,能及时存储采集到的数据。本系统已经应用于某信号采集设备中,实践证明可满足使用要求,能够满足80Khz数据采样率系统的存盘要求。
2 系统实现方案
本设计采用FPGA和DSP直接控制硬盘[1][2],并采用一片FIFO作为数据缓存,系统采用DSP完成文件管理工作,利用FPGA实现DSP与硬盘的接口。具体框图如图1所示。
图1 方案实现框图
首先由采集控制板FPGA将FIFO复位,需要储存数据时数据流直接将数据写入FIFO,当存储控制板FPGA查询到FIFO的状态为非空时就输出BIO信号通知DSP启动存盘程序。DSP先访问硬盘确定所需参数,如下一个文件应使用的文件名,保存文件的逻辑扇区号等。然后DSP向硬盘发出存盘命令,当硬盘响应控制命令后,DSP通知FPGA可以向硬盘传输数据。存盘时FPGA从FIFO中读出数据并将数据打包,由8bit变为16bit,并写入硬盘数据寄存器。当存满40M时,DSP通知采集控制系统已写满一个文件,采集控制系统将FIFO复位完成一次存盘操作。
硬盘中数据如何存储是本设计中另一个重点问题,主要考虑文件存储的地址及文件目录情况。本设计中硬盘文件的存储采用FAT32文件系统,引导扇区记录了文件分配表的地址、个数、大小、簇的大小等信息。文件逻辑地址=数据段起始地址+(簇号— RootClus)×SecPerClus;数据段起始地址=BPB地址+RsvdSecCn+FATSz32×NumFATs。)文件目录设计采用短文件名,每个文件名和相关信息占用32字节,每个磁盘第2簇为目录区,因使用短文件名无子目录,所以当每簇为16扇区时目录区共可储存256个文件名。
6 结束语
本系统数据存储量较大,较传统使用工控机进行数据存储功耗较低,适合于工作环境局限、系统要求具有自动内记功能的工况下。本系统已经应用于某信号采集设备中,实践证明可满足使用要求,系统工作稳定,没有数据溢出现象。当然本系统还有一定不足,如不能存储任意长度数据文件,只能存储40M长度文件,还需进一步完善。
一周热门 更多>