当前位置:首页 > EDA > 电子设计自动化
[导读] 摘 要 介绍了采用FPGA和DSP直接控制硬盘进行数据存储的方法,并采用一片FIFO作为数据缓存,能够满足80Khz数据采样率系统的存盘要求。 关键词 FPGA;DSP;硬盘;数据存储 1 引言 数据存储是数据采集过程中

 摘  要  介绍了采用FPGADSP直接控制硬盘进行数据存储的方法,并采用一片FIFO作为数据缓存,能够满足80Khz数据采样率系统的存盘要求。
    关键词  FPGA;DSP;硬盘;数据存储
 
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复位完成一次存盘操作。
3 存储控制程序流程
    程序启动后,首先将硬盘Device register中的SRST置1使硬盘复位,在硬盘复位后读取MBR0和BPB0,在FAT中找到Special Sector并检查是否有标志位0x55FF,如果没有则说明硬盘是第1次被使用,如果有则从中读取参数准备传输数据。
    (1) 为了在每次启动程序后能迅速查找到应使用的文件名、下一个空簇的位置、正在使用的磁盘等参数,将硬盘第3簇中第1扇区标志为Special Sector,用于储存这些参数。

    (2)每个磁盘被划分出200M空间为保留区,当发现磁盘空间不足200M时即显示磁盘已满,不在用当前磁盘存储数据而是使用下一个磁盘。
    (3)每个磁盘第2簇为目录区,因使用短文件名无子目录,所以当每簇为16扇区时目录区共可储存256个文件名。
    (4)数据文件大小固定为40M。
    如果硬盘是第一次被使用,则主机顺次读取MBR0、BPB0、MBR1、BPB1直到查询到最后一个硬盘分区,并将相关参数如每个分区的大小、分区的逻辑地址、每个分区数据空间起始段的逻辑地址、FAT表逻辑地址等信息写入Special Sector,并做一个文件的目录(32字节)将第一个文件命名为“000.dat”。
    当FAT中第三簇被标志为坏簇时,表明已经在硬盘上划分Special Sector并已存入硬盘参数。主机从Special Sector中读取下一个可用空簇,并计算这一簇在FAT中的位置并将FAT读入C54的RAM中,读取Special Sector中的文件名及相关参数并将其写入目录区。然后查询BIO,当BIO为低电平时开始传输数据(参见储存板接口),传输数据时FPGA启动元件 trans_data,由主机发出XF作为启动信号。FPGA从FIFO中每读出2Bytes向硬盘写一次,连续写256次,即向硬盘传输512字节数据。主机每发出一个XF下降沿FPGA就从FIFO中读取512字节数据并存入硬盘。
    传输40M数据结束后,主机将根据传输的扇区数填写FAT表,判断硬盘空间是否小于200M、已储存的文件数是否大于256,如果为真则再次存储数据时将使用下一个磁盘分区。
4 硬盘操作控制流程
    我们一般习惯称硬盘接口为IDE接口[3],对硬盘的操作如读写扇区,发送命令等都是通过读写寄存器来完成的,每向硬盘发送一组命令后都要读取状态寄存器中的信息,通过状态寄存器的值来判断硬盘是否已经执行完所发送的命令。
4.1  硬盘启动操作
    硬盘加电后应先将硬盘复位,硬盘复位方式有三种,本设计采用的是将SRST置1,当SRST被置1后硬盘立即复位,这时应至少等待2ms才读取Status register。如果Status register的值为80h,则表明硬盘已完成复位。硬盘启动流程见图2。

图2 硬盘启动程序流程图   

图3  扇区读写操作程序流程图
4.2  扇区读写操作
    首先应向硬盘发送命令参数,将要读写的扇区数目写入Sector count register,将扇区的逻辑地址写入LBA High register、LBA Mid register和LBA Low register,将要接收命令的设备号写入Device register。流程见图3。
    LBA=(柱面编号×磁头数+磁头编号)×扇区数+扇区编号-1
    将命令READ SECTOR或WRITE SECTOR写入Command register后,在400ns内Status register的值并不可靠,所以需等待400ns才能读取Status register,这段等待时间可以通过读取Alternate Status register和Error register度过,读取的数值应被丢弃。当状态寄存器的值为58h时,表示硬盘已经可以从Data register接收或传输数据。                    
4.3  DMA操作流程
    DMA操作与I/O操作相似,流程见图4,首先应向硬盘发送命令参数,将要读写的扇区数目写入 Sector count register,将扇区的逻辑地址写入LBA High register、LBA Mid register和LBA Low register,将要接收命令的设备号写入Device register。将命令READ DMA或 WRITE DMA写入Command register后,在400ns内Status register的值并不可靠,所以需等待400ns才能读取Status register,这段等待时间可以通过读取Alternate Status register和Error register度过,读取的数值应被丢弃。当状态寄存器值为58h时主机应给出DMA初始化时序开始传输数据。

 
                           
图4  DMA操作流程图
5 设计中的重点
5.1  采样率问题
    数据采集及存储系统一般都有采样率要求,采样率一般要求大于50K,才能满足快速实时采集数据的要求。本系统中速度较慢的环节是硬盘存储环节,硬盘接口设计存盘速度为7.8Mbyte/S,显然采集速率与存盘速率并不匹配,解决的措施为采用一片 FIFO作为数据缓冲区。由于对硬盘操作过程中,需不断查询其状态,而硬盘状态改变时间又不确定,所以要选用存储深度较大的FIFO作为缓存,IDT公司的72V2101满足设计要求[5]。工作时数据直接将数据写入FIFO,FPGA查询FIFO的状态,为非空时,协调DSP访问硬盘,进行存储操作,这样采用FIFO作为缓存的方案解决了速率匹配问题[4],当采样率为80k时,数据流为5Mbyte/S,本系统设计存盘速度为7.8Mbyte/S,可以满足80K以内数据采样率系统的存盘要求。
5.2  硬盘存储地址问题
    硬盘中数据如何存储是本设计中另一个重点问题,主要考虑文件存储的地址及文件目录情况。本设计中硬盘文件的存储采用FAT32文件系统,引导扇区记录了文件分配表的地址、个数、大小、簇的大小等信息。文件逻辑地址=数据段起始地址+(簇号— RootClus)×SecPerClus;数据段起始地址=BPB地址+RsvdSecCn+FATSz32×NumFATs。)文件目录设计采用短文件名,每个文件名和相关信息占用32字节,每个磁盘第2簇为目录区,因使用短文件名无子目录,所以当每簇为16扇区时目录区共可储存256个文件名。
6 结束语
    本系统数据存储量较大,较传统使用工控机进行数据存储功耗较低,适合于工作环境局限、系统要求具有自动内记功能的工况下。本系统已经应用于某信号采集设备中,实践证明可满足使用要求,系统工作稳定,没有数据溢出现象。当然本系统还有一定不足,如不能存储任意长度数据文件,只能存储40M长度文件,还需进一步完善。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

上海2022年10月18日 /美通社/ -- 2022年9月5日,是首都银行集团成立60周年的纪念日。趁着首都银行集团成立60周年与首都银行(中国)在华深耕经营12年的“大日子”,围绕作为外资金融机构对在华战略的构想和业...

关键字: 数字化 BSP 供应链 控制

根据害虫控制公司Orkin最新发布的“美国鼠患最严重的城市”年度调查,芝加哥连续第八年排在第一。报告统计时间从2021年9月1日至2022年8月31日,包括住宅楼和商业地产。纽约上升至第二,洛杉矶第三。每年秋季,老鼠和其...

关键字: 控制

最近为什么越来越多的研究开始利用FPGA作为CNN加速器?FPGA与CNN的相遇究竟能带来什么神奇效果呢?原来,FPGA拥有大量的可编程逻辑资源,相对于GPU,它的可重构性以及高功耗能效比的优点,是GPU无法比拟的;同时...

关键字: FPGA 可编程逻辑资源 GPU

FPGA的应用领域包罗万象,我们今天来看看在音乐科技领域及医疗照护的智能巧思。

关键字: FPGA 科技领域 智能

针对财会专业人士的调查显示,大多数组织的财会专业人员都已经迈出了转型步伐,但尚未做好准备满足组织对于未来财会职能的要求,即具备更高的洞察力和预见力 北京2022年10月13日 /美通社/ -- IMA管理会计师协会与德...

关键字: 控制 数字化 MIDDOT BSP

强大的产品可降低信号噪音并提高分辨率与动态

关键字: Spectrum仪器 数字化仪 FPGA

上海2022年10月11日 /美通社/ -- 10月10日,和睦家医疗宣布与泰利福达成战略合作,签约仪式于上海和睦家医院圆满举办,并在线上与多位泌尿外科领域翘楚同步连线召开"微创经尿道前列腺悬扩术(PUL)&q...

关键字: 创始人 CE 微型 控制

上海2022年10月11日 /美通社/ -- 10月10日,明月镜片正式官宣刘昊然成为品牌代言人。一个是中国镜片领导品牌,通过科技创新引领了镜片行业的发展;一个是新生代实力演员,凭借高票房作品赢得了观众的认可。此次双方携...

关键字: PMC 控制 节点 蓝光

最近某项目采用以太网通信,实践起来有些奇怪,好像设计成只能应答某类计算机的ICMP(ping)命令, 某类计算机指的是Windows特定系统,其他系统发送ping都不能正确识别。

关键字: 嵌入式Linux FPGA 协议

近两年,国外厂商的FPGA芯片价格飙升,由于价格,货期,出口管制等多方面因素的影响,很多公司都在寻找FPGA国产化替代方案。我工作中正在使用的几款芯片也面临停产的风险,用一片少一片,了解到国产FPGA发展的也不错,完全自...

关键字: FPGA 芯片 EDA

电子设计自动化

21191 篇文章

关注

发布文章

编辑精选

技术子站

关闭