新聞中心

        EEPW首頁 > EDA/PCB > 設計應用 > 采用FPGA和DSP直接控制硬盤實現存儲控制的方法

        采用FPGA和DSP直接控制硬盤實現存儲控制的方法

        作者: 時間:2010-01-11 來源:網絡 收藏

        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初始化時序開始傳輸數據。

        本文引用地址:http://www.104case.com/article/191820.htm



        圖4  DMA操作流程圖
        5 設計中的重點
        5.1 采樣率問題
        數據采集及存儲系統一般都有采樣率要求,采樣率一般要求大于50K,才能滿足快速實時采集數據的要求。本系統中速度較慢的環節是存儲環節,接口設計存盤速度為7.8Mbyte/S,顯然采集速率與存盤速率并不匹配,解決的措施為采用一片 FIFO作為數據緩沖區。由于對硬盤操作過程中,需不斷查詢其狀態,而硬盤狀態改變時間又不確定,所以要選用存儲深度較大的FIFO作為緩存,IDT公司的72V2101滿足設計要求[5]。工作時數據直接將數據寫入FIFO,查詢FIFO的狀態,為非空時,協調訪問硬盤,進行存儲操作,這樣采用FIFO作為緩存的方案解決了速率匹配問題[4],當采樣率為80k時,數據流為5Mbyte/S,本系統設計存盤速度為7.8Mbyte/S,可以滿足80K以內數據采樣率系統的存盤要求。
        5.2 硬盤存儲地址問題
        硬盤中數據如何存儲是本設計中另一個重點問題,主要考慮文件存儲的地址及文件目錄情況。本設計中硬盤文件的存儲采用FAT32文件系統,引導扇區記錄了文件分配表的地址、個數、大小、簇的大小等信息。文件邏輯地址=數據段起始地址+(簇號― RootClus)×SecPerClus;數據段起始地址=BPB地址+RsvdSecCn+FATSz32×NumFATs。)文件目錄設計采用短文件名,每個文件名和相關信息占用32字節,每個磁盤第2簇為目錄區,因使用短文件名無子目錄,所以當每簇為16扇區時目錄區共可儲存256個文件名。
        6 結束語
        本系統數據存儲量較大,較傳統使用工控機進行數據存儲功耗較低,適合于工作環境局限、系統要求具有自動內記功能的工況下。本系統已經應用于某信號采集設備中,實踐證明可滿足使用要求,系統工作穩定,沒有數據溢出現象。當然本系統還有一定不足,如不能存儲任意長度數據文件,只能存儲40M長度文件,還需進一步完善。


        上一頁 1 2 3 下一頁

        關鍵詞: FPGA DSP 直接控制 硬盤

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 连山| 武邑县| 招远市| 巴南区| 肃北| 东阳市| 新兴县| 吴堡县| 桃园县| 贵定县| 昌平区| 纳雍县| 潞西市| 策勒县| 微山县| 诸暨市| 长子县| 达孜县| 临安市| 乌审旗| 昭平县| 阿拉善盟| 疏附县| 鸡东县| 桂林市| 延长县| 屯留县| 诸暨市| 澄江县| 偏关县| 六安市| 贵港市| 鹤庆县| 泾源县| 蒙自县| 北流市| 吴堡县| 中方县| 洪雅县| 凉城县| 常德市|