<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > EDA/PCB > 設(shè)計(jì)應(yīng)用 > 采用FPGA和DSP直接控制硬盤實(shí)現(xiàn)存儲(chǔ)控制的方法

          采用FPGA和DSP直接控制硬盤實(shí)現(xiàn)存儲(chǔ)控制的方法

          作者: 時(shí)間:2010-01-11 來源:網(wǎng)絡(luò) 收藏

          傳輸40M數(shù)據(jù)結(jié)束后,主機(jī)將根據(jù)傳輸?shù)纳葏^(qū)數(shù)填寫FAT表,判斷空間是否小于200M、已儲(chǔ)存的文件數(shù)是否大于256,如果為真則再次存儲(chǔ)數(shù)據(jù)時(shí)將使用下一個(gè)磁盤分區(qū)。
          4 操作控制流程
          我們一般習(xí)慣稱接口為IDE接口[3],對硬盤的操作如讀寫扇區(qū),發(fā)送命令等都是通過讀寫寄存器來完成的,每向硬盤發(fā)送一組命令后都要讀取狀態(tài)寄存器中的信息,通過狀態(tài)寄存器的值來判斷硬盤是否已經(jīng)執(zhí)行完所發(fā)送的命令。
          4.1 硬盤啟動(dòng)操作
          硬盤加電后應(yīng)先將硬盤復(fù)位,硬盤復(fù)位方式有三種,本設(shè)計(jì)采用的是將SRST置1,當(dāng)SRST被置1后硬盤立即復(fù)位,這時(shí)應(yīng)至少等待2ms才讀取Status register。如果Status register的值為80h,則表明硬盤已完成復(fù)位。硬盤啟動(dòng)流程見圖2。

          本文引用地址:http://www.ex-cimer.com/article/191820.htm

          圖2 硬盤啟動(dòng)程序流程圖

          圖3 扇區(qū)讀寫操作程序流程圖
          4.2 扇區(qū)讀寫操作
          首先應(yīng)向硬盤發(fā)送命令參數(shù),將要讀寫的扇區(qū)數(shù)目寫入Sector count register,將扇區(qū)的邏輯地址寫入LBA High register、LBA Mid register和LBA Low register,將要接收命令的設(shè)備號(hào)寫入Device register。流程見圖3。
          LBA=(柱面編號(hào)×磁頭數(shù)+磁頭編號(hào))×扇區(qū)數(shù)+扇區(qū)編號(hào)-1
          將命令READ SECTOR或WRITE SECTOR寫入Command register后,在400ns內(nèi)Status register的值并不可靠,所以需等待400ns才能讀取Status register,這段等待時(shí)間可以通過讀取Alternate Status register和Error register度過,讀取的數(shù)值應(yīng)被丟棄。當(dāng)狀態(tài)寄存器的值為58h時(shí),表示硬盤已經(jīng)可以從Data register接收或傳輸數(shù)據(jù)。



          關(guān)鍵詞: FPGA DSP 直接控制 硬盤

          評(píng)論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();