《電子技術(shù)應(yīng)用》
您所在的位置:首頁(yè) > 可編程邏輯 > 設(shè)計(jì)應(yīng)用 > 個(gè)人/家庭網(wǎng)絡(luò)硬盤的設(shè)計(jì)及實(shí)現(xiàn)
個(gè)人/家庭網(wǎng)絡(luò)硬盤的設(shè)計(jì)及實(shí)現(xiàn)
來(lái)源:電子技術(shù)應(yīng)用2012年第12期
劉 劍,張 剛,常 青
太原理工大學(xué) 信息工程學(xué)院,山西 太原030024
摘要: 利用Xilinx公司的XUPV5 LX110T FPGA開發(fā)板設(shè)計(jì)并掛載ATA控制器的IP核,在移植的PetaLinux操作系統(tǒng)中添加獨(dú)立的FAT32文件系統(tǒng)模塊。用戶通過操作Web瀏覽器調(diào)用相應(yīng)的CGI程序即可實(shí)現(xiàn)對(duì)硬盤的遠(yuǎn)程訪問。
中圖分類號(hào): TP368.2
文獻(xiàn)標(biāo)識(shí)碼: A
文章編號(hào): 0258-7998(2012)12-0023-03
Design and implementation of the personal/home network disk
Liu Jian,Zhang Gang,Chang Qing
College of Information Engineering, Taiyuan University of Technology, Taiyuan 030024,China
Abstract: To establish the remote access to hard drives, it is necessary to utilize Xilinx's XUPV5 LX110T FPGA development board mounted with ATA controller IP core, and add an independ FAT32 file system module to PetaLinux operating system. The users can run specific CGI programs via Web Explorers.
Key words : network disk;FPGA;FAT file system;CGI

    USB移動(dòng)硬盤需要用戶隨身攜帶,易感染病毒且主機(jī)關(guān)機(jī)后無(wú)法使用。隨著高性能網(wǎng)絡(luò)技術(shù)的不斷進(jìn)步,網(wǎng)絡(luò)存儲(chǔ)方式逐漸興起[1],個(gè)人/家庭網(wǎng)絡(luò)硬盤是為適應(yīng)當(dāng)前對(duì)遠(yuǎn)程文件資源訪問的迫切需求而設(shè)計(jì)開發(fā)的一種基于FPGA的嵌入式網(wǎng)絡(luò)存儲(chǔ)設(shè)備。它是一種將文件上傳至服務(wù)器主機(jī)、用戶可在任意地點(diǎn)的客戶端上通過網(wǎng)絡(luò)訪問該文件的存儲(chǔ)方式。

    本文設(shè)計(jì)實(shí)現(xiàn)了一種基于FPGA的個(gè)人/家庭網(wǎng)絡(luò)硬盤,其系統(tǒng)整體架構(gòu)如圖1所示,分為硬件層、內(nèi)核層及用戶層。用戶層是系統(tǒng)的交互操作界面,硬件層實(shí)現(xiàn)系統(tǒng)對(duì)底層硬盤的各種操作,內(nèi)核層負(fù)責(zé)在用戶層與硬件層之間傳遞驅(qū)動(dòng)的相關(guān)參數(shù)及數(shù)據(jù)。利用XUPV5 LX110T FPGA開發(fā)板設(shè)計(jì)并掛載ATA控制器的IP核;移植PetaLinux操作系統(tǒng)并添加獨(dú)立的FAT32文件系統(tǒng)模塊;用戶端采用B/S模式。由于用戶端是標(biāo)準(zhǔn)的瀏覽器,用戶只需要一臺(tái)能上網(wǎng)的PC機(jī)就可利用Web瀏覽器調(diào)用相應(yīng)的通用網(wǎng)關(guān)接口CGI(Common Gateway Interface)程序完成對(duì)硬盤的遠(yuǎn)程操作。個(gè)人/家庭網(wǎng)絡(luò)硬盤可全天候不間斷工作,方便快捷,通過掛載多個(gè)硬盤可擴(kuò)展用戶存儲(chǔ)容量。未來(lái)可以參考本文提出的通用方法結(jié)合不同的需求對(duì)系統(tǒng)進(jìn)一步開發(fā)與完善。

1 系統(tǒng)設(shè)計(jì)
1.1 硬件平臺(tái)簡(jiǎn)介

    系統(tǒng)硬件平臺(tái)結(jié)構(gòu)如圖2所示。系統(tǒng)采用Xilinx公司的XUPV5 LX110T FPGA開發(fā)板,內(nèi)嵌MicroBlaze軟核、以太網(wǎng)控制器、Flash、DDR等模塊,通過PLB總線實(shí)現(xiàn)模塊之間的交互通信。底層數(shù)據(jù)存儲(chǔ)設(shè)備使用具有IDE接口的ATA硬盤,通過V5開發(fā)板的擴(kuò)展接口與FPGA芯片相連,用戶端通過訪問網(wǎng)絡(luò)實(shí)現(xiàn)對(duì)硬盤的遠(yuǎn)程訪問。


    圖2模塊中,除陰影所示模塊需自行開發(fā)外,其他部分均由XUPV5 LX110T FPGA開發(fā)板提供。
1.2 ATA主機(jī)控制器的IP核設(shè)計(jì)
    本文采用具有IDE接口的希捷ST340014A硬盤(40 GB)作為數(shù)據(jù)存儲(chǔ)設(shè)備,依據(jù)ATA/ATAPI-6協(xié)議[2]完成了對(duì)ATA主機(jī)控制器的設(shè)計(jì),并將其封裝為IP核以方便集成到不同總線結(jié)構(gòu)的ASIC或SoC系統(tǒng)中[3]。ATA主機(jī)控制器的結(jié)構(gòu)如圖3所示。


    硬件層的ATA主機(jī)控制器包括復(fù)位、PIO控制、MDMA(Multiword DMA)控制、Ultra DMA控制、接收/發(fā)送緩存等6個(gè)主要模塊,全部用VHDL語(yǔ)言編程實(shí)現(xiàn),仿真調(diào)試通過。其中,復(fù)位模塊在初始化或異常情況下對(duì)各個(gè)模塊的重置復(fù)位;PIO模塊控制PIO模式的讀寫硬盤操作;MDMA模塊實(shí)現(xiàn)對(duì)硬盤的多字DMA模式讀寫操作;Ultra DMA控制模塊用于實(shí)現(xiàn)對(duì)以Ultra DMA方式訪問硬盤的整個(gè)流程的控制;接收/發(fā)送緩存模塊用于控制數(shù)據(jù)的緩存。
    實(shí)現(xiàn)ATA主機(jī)控制器的關(guān)鍵除了要按要求設(shè)計(jì)嚴(yán)格的時(shí)序邏輯及狀態(tài)機(jī)外,還需要實(shí)現(xiàn)對(duì)協(xié)議指定寄存器的讀寫操作。因?yàn)槊罴懊顓?shù)的傳遞、設(shè)備狀態(tài)信息的傳遞都是通過對(duì)寄存器的讀寫來(lái)完成的。ATA協(xié)議中各寄存器的數(shù)據(jù)傳輸遵守PIO傳輸模式,通過設(shè)置CS1-、CS0-和DA[2:0]選通寄存器地址,DIOR-/DIOW-信號(hào)控制讀寫。同時(shí),ATA主機(jī)控制器或硬盤把待傳送的數(shù)據(jù)放到數(shù)據(jù)總線上,并根據(jù)數(shù)據(jù)傳送的方向由控制器或硬盤讀取總線上的數(shù)據(jù)。ATA/ATAPI-6協(xié)議中各寄存器[4]的定義如表1所示。
    實(shí)現(xiàn)內(nèi)核驅(qū)動(dòng)與底層硬盤的對(duì)接過程為:首先將VHDL設(shè)計(jì)的ATA主控制器模塊封裝成用戶定制的IP核,通過PLB總線與MicroBlaze處理器互連;其次對(duì)XGpio函數(shù)進(jìn)行封裝。硬盤驅(qū)動(dòng)定義如表2所示。

1.3 FAT文件系統(tǒng)
    文件系統(tǒng)作為操作系統(tǒng)與底層硬件之間的橋梁,在嵌入式系統(tǒng)等各個(gè)領(lǐng)域得到了廣泛的應(yīng)用。當(dāng)前U盤、MP3、MP4等設(shè)備幾乎都采用了微軟公司FAT32[5]文件系統(tǒng),但由于并未公布FAT32文件系統(tǒng)的源碼,本文采用開源項(xiàng)目FatFS[6]。FatFS獨(dú)立于底層的DISK I/O層,不依賴于硬件架構(gòu)并與Windows的FAT文件系統(tǒng)有著良好的兼容性。
    FAT文件系統(tǒng)可劃分為需求、邏輯和物理三個(gè)層次。需求層支持用戶的基本文件操作;邏輯層實(shí)現(xiàn)FAT文件系統(tǒng)到物理層的映射;物理層實(shí)現(xiàn)與物理存儲(chǔ)介質(zhì)的接口(包括基本的讀寫扇區(qū)、硬盤復(fù)位等操作)。物理層主要實(shí)現(xiàn)5個(gè)接口:disk_initialize(初始化磁盤驅(qū)動(dòng)器)、disk_status(獲取磁盤狀態(tài))、disk_read(讀扇區(qū))、disk_write(寫扇區(qū))、disk_ioctl(控制設(shè)備關(guān)聯(lián)特性)。利用這5個(gè)接口可以實(shí)現(xiàn)FAT文件系統(tǒng)的需求和邏輯。
    文件系統(tǒng)物理層的5個(gè)接口函數(shù)調(diào)用PetaLinux內(nèi)核驅(qū)動(dòng)實(shí)現(xiàn)底層硬盤與文件系統(tǒng)的對(duì)接,進(jìn)而實(shí)現(xiàn)FAT文件系統(tǒng)的各個(gè)流程,例如讀扇區(qū)disk_read操作將調(diào)用表2中定義的xgpio_ata_ioctl、xgpio_ata_read等驅(qū)動(dòng)函數(shù),這些函數(shù)實(shí)現(xiàn)了ATA IP核中對(duì)相應(yīng)的寄存器讀寫功能。首先,將參數(shù)及數(shù)據(jù)傳遞到內(nèi)核中;其次,將xgpio_ata_ioctl、xgpio_ata_read等驅(qū)動(dòng)函數(shù)封裝到應(yīng)用層中的disk_read中,滿足文件系統(tǒng)邏輯層的需求,進(jìn)而實(shí)現(xiàn)文件系統(tǒng)需求層各個(gè)接口。所有的FAT文件系統(tǒng)操作流程都封裝為庫(kù),被用戶直接調(diào)用。文件系統(tǒng)的接口函數(shù)全部被定義到應(yīng)用層,供CGI調(diào)用。
    經(jīng)測(cè)試,編寫的FatFS文件系統(tǒng)物理層接口函數(shù)工作正常,可以滿足邏輯層、需求層的所有需求。
1.4 用戶接口
    PetaLinux操作系統(tǒng)是專門用于FPGA的全功能嵌入式Linux操作系統(tǒng)[7],用戶可使用其自帶的工具方便快捷地搭建所需的開發(fā)環(huán)境。PetaLinux中集成了對(duì)部分常用IP核的支持,減少了用戶移植、編寫驅(qū)動(dòng)的工作量。同時(shí)源碼中包含大量的腳本語(yǔ)言,簡(jiǎn)化了操作。編譯生成并拷貝FatFS庫(kù)到PetaLinux /bin目錄下,用戶便可將其作為應(yīng)用程序進(jìn)行調(diào)用。
    用戶和整體系統(tǒng)的接口通過滿足CGI規(guī)范的C語(yǔ)言編寫實(shí)現(xiàn)。服務(wù)器采用完全支持CGI的高性能單任務(wù)型嵌入式Web服務(wù)器Boa。移植PetaLinux時(shí)需開啟對(duì)Boa的支持。
    GI工作流程:當(dāng)輸入目標(biāo)板的IP地址后,用戶的Web瀏覽器與Boa服務(wù)器建立TCP連接;當(dāng)在Web頁(yè)面上完成一定操作后,將會(huì)向PetaLinux中的Boa服務(wù)器發(fā)出CGI請(qǐng)求,Boa服務(wù)器接收到該請(qǐng)求后將會(huì)創(chuàng)建一個(gè)CGI進(jìn)程,并將具體的環(huán)境變量、參數(shù)與標(biāo)準(zhǔn)的輸入方式傳遞給CGI程序;CGI程序完成相應(yīng)的處理后再將結(jié)果傳給Boa服務(wù)器,服務(wù)器將輸出內(nèi)容添加一定的標(biāo)識(shí)信息后以HTML頁(yè)面的形式返回并呈現(xiàn)給用戶[8],具體流程如圖4所示。例如,用戶點(diǎn)擊&ldquo;Read&rdquo;按鈕時(shí),將觸發(fā)HTML頁(yè)面中的表單并向服務(wù)器發(fā)出HTTP請(qǐng)求(CGI請(qǐng)求),發(fā)往<FORM>標(biāo)記中的ACTION 屬性標(biāo)識(shí)的地址(此處為CGI處理程序)。

2 系統(tǒng)特點(diǎn)
    個(gè)人/家庭網(wǎng)絡(luò)硬盤具以下特點(diǎn):
    (1)較高的私有性及安全性。存儲(chǔ)設(shè)備用戶可見,確保了用戶數(shù)據(jù)的私有性及安全性;
    (2)即插即用。安裝簡(jiǎn)單,插上電源及網(wǎng)線即可使用;
    (3)采用瀏覽器訪問。只要一臺(tái)可以上網(wǎng)的PC機(jī),利用瀏覽器即可實(shí)現(xiàn)對(duì)硬盤的訪問;
    (4)易操作和易擴(kuò)展。通過增加硬盤數(shù)量或更換存儲(chǔ)介質(zhì)可以支持用戶擴(kuò)充存儲(chǔ)容量。
    實(shí)驗(yàn)室測(cè)試環(huán)境中,在瀏覽器輸入開發(fā)板IP地址(192.168.0.10)與FPGA開發(fā)板建立連接,用戶操作主界面如圖5所示。

 

 

    點(diǎn)擊&ldquo;上傳文件&rdquo;按鈕后將提示用戶選擇要上傳的文件,文件確定后點(diǎn)擊&ldquo;Submit&rdquo;將執(zhí)行上傳文件的操作,即由本地主機(jī)寫入至遠(yuǎn)端的硬盤中。
    本文設(shè)計(jì)并實(shí)現(xiàn)的個(gè)人/家庭網(wǎng)絡(luò)硬盤,在XUPV5 LX110T FPGA開發(fā)板上掛載了ATA控制器的IP核、移植了PetaLinux操作系統(tǒng)、添加了獨(dú)立的FAT32文件系統(tǒng)模塊、設(shè)計(jì)了硬盤的人機(jī)交互界面,通過實(shí)際系統(tǒng)驗(yàn)證證明了該方案的可行性。未來(lái)可結(jié)合相應(yīng)的需求對(duì)個(gè)人/家庭網(wǎng)絡(luò)硬盤進(jìn)一步開發(fā)與完善。
參考文獻(xiàn)
[1] 鄧玉輝.基于網(wǎng)絡(luò)磁盤陣列的海量信息存儲(chǔ)系統(tǒng)[D].武漢:華中科技大學(xué),2004.
[2] ANSI INCITS.Information technology-AT attachment with packet interface-6[S].USA:T13 Technical Committee,2002.
[3] 齊作府.基于FPGA的ATA Device IP研究[D].阜新:遼寧工程技術(shù)大學(xué),2008.
[4] 李曉娟.基于FPGA的Ultra DMA寫控制器的實(shí)現(xiàn)[J].科學(xué)技術(shù)與工程,2007(15):3746-3749.
[5] Microsoft Corporation.Microsoft EFI FAT32 file system specification[S].2000.
[6] FatFs generic FAT file system module[EB/OL].(2011-11-04)[2012-04-20].http://elm-chan.org/fsw/ff/ 00index_e.html.
[7] 薛慧敏,武傳華,路后兵,等.基于MicroBlaze的PetaLinux 嵌入式操作系統(tǒng)移植[J].微計(jì)算機(jī)信息,2011,27(8):108-110.
[8] 劉輝,劉毅敏.嵌入式Web服務(wù)器的研究與設(shè)計(jì)[J].數(shù)字通信,2011(4):78-81.

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
国产欧美日本| 一区二区三区亚洲| 欧美视频三区在线播放| 欧美日韩在线一区二区| 欧美 日韩 国产 一区| 久久蜜桃精品| 久久亚洲精品欧美| 久久在线视频| 乱中年女人伦av一区二区| 久久精品女人| 久久人人爽爽爽人久久久| 久久久999| 久久久www| 久久成人免费| 久久国产精品久久国产精品| 欧美一级视频| 久久激情五月丁香伊人| 久久国产精品72免费观看| 欧美在线高清视频| 久久精品国产第一区二区三区| 欧美在线三级| 久久精品一二三| 久久人人爽国产| 狂野欧美性猛交xxxx巴西| 蜜桃伊人久久| 欧美日本高清| 国产精品v一区二区三区| 国产精品观看| 国产欧美日韩视频| 红杏aⅴ成人免费视频| 尤物九九久久国产精品的分类| 在线观看视频欧美| 最近看过的日韩成人| 亚洲精品一区二区在线| 夜夜嗨av一区二区三区网页| 亚洲丝袜av一区| 午夜电影亚洲| 亚洲国产精品福利| 日韩亚洲欧美成人| 亚洲综合大片69999| 欧美中文日韩| 亚洲一区欧美激情| 免费观看成人| 久久国产视频网| 嫩模写真一区二区三区三州| 欧美精品一区二区三区蜜臀| 欧美午夜国产| 国产亚洲欧美日韩日本| 在线成人亚洲| 久久久久综合网| 久久久综合激的五月天| 久久精品夜夜夜夜久久| 欧美黄色精品| 国产精品日韩高清| 在线观看成人av| 一区二区日韩伦理片| 欧美在线观看视频一区二区| 亚洲人www| 亚洲主播在线播放| 久久中文字幕导航| 欧美日韩一区在线观看视频| 国产欧美一区二区三区久久| 在线国产亚洲欧美| 国产精品99久久久久久宅男| 亚洲丁香婷深爱综合| 中日韩高清电影网| 久久频这里精品99香蕉| 欧美日韩综合视频| 樱花yy私人影院亚洲| 亚洲午夜激情| 亚洲免费观看视频| 久久精品亚洲精品国产欧美kt∨| 欧美激情国产精品| 国产一区二区三区精品久久久| 亚洲欧洲午夜| 欧美一级专区| 亚洲专区免费| 欧美精品乱码久久久久久按摩| 国产欧美日韩三区| 一区二区成人精品| 亚洲人妖在线| 久久精品久久99精品久久| 欧美日韩国产首页| 精品盗摄一区二区三区| 亚洲在线视频网站| 一区二区高清视频| 免费精品99久久国产综合精品| 国产精品综合不卡av| 亚洲人成网站色ww在线| 亚洲大胆人体在线| 欧美影视一区| 国产精品久久久一区麻豆最新章节| 亚洲国产精品视频一区| 欧美在线一级视频| 先锋影院在线亚洲| 欧美日韩国产限制| 亚洲国产精品一区二区尤物区| 欧美主播一区二区三区| 午夜精品免费在线| 欧美午夜精品久久久| 亚洲欧洲久久| 91久久夜色精品国产九色| 久久精品主播| 国产精品视频观看| 中文日韩在线视频| 亚洲视频大全| 欧美日韩国产成人在线免费| 亚洲国内在线| 亚洲人成久久| 噜噜噜躁狠狠躁狠狠精品视频| 国内成人精品2018免费看 | 国产午夜一区二区三区| 亚洲午夜精品久久久久久app| 日韩视频永久免费| 欧美 日韩 国产在线| 黑人极品videos精品欧美裸| 欧美伊人久久久久久久久影院 | 亚洲视频在线观看免费| 亚洲午夜电影在线观看| 欧美日韩亚洲一区二区三区四区 | 亚洲国产精品久久久久婷婷884| 亚洲国产人成综合网站| 久久久久国产精品人| 国产欧美精品一区aⅴ影院| 亚洲私人影吧| 性欧美大战久久久久久久免费观看 | 亚洲黄色成人网| 亚洲精品你懂的| 欧美国内亚洲| 亚洲人成网站777色婷婷| 日韩午夜在线| 欧美日韩免费在线观看| 日韩视频在线播放| 中文日韩欧美| 欧美视频在线看| 亚洲一区二区三区影院| 欧美在线免费看| 国产午夜精品在线| 亚洲国产精品t66y| 欧美激情视频给我| 99精品久久久| 午夜日韩视频| 国产主播一区二区三区四区| 亚洲韩国青草视频| 欧美女人交a| 亚洲无吗在线| 久久国产综合精品| 在线播放精品| 亚洲免费观看高清完整版在线观看熊| 欧美日韩国产在线| 亚洲淫性视频| 久久久欧美精品| 91久久夜色精品国产九色| 亚洲一区二区成人| 国产日产欧美精品| 亚洲国产精品成人久久综合一区| 欧美精品综合| 亚洲婷婷国产精品电影人久久| 久久精品国产亚洲精品| 在线看片欧美| 亚洲手机视频| 国内精品久久久久影院 日本资源| 亚洲日本在线观看| 欧美性天天影院| 欧美一区日本一区韩国一区| 免费欧美高清视频| 日韩午夜高潮| 久久国产精品99国产| 亚洲高清在线| 午夜亚洲激情| 在线观看不卡| 欧美一区2区三区4区公司二百| 激情视频一区二区三区| 在线视频精品一| 国产亚洲视频在线| 艳女tv在线观看国产一区| 国产日韩在线亚洲字幕中文| 亚洲精品少妇30p| 国产精品婷婷| 亚洲乱码国产乱码精品精天堂| 国产精品女同互慰在线看| 最新日韩中文字幕| 国产精品日日摸夜夜摸av| 亚洲精品1区| 国产精品一二三| 亚洲毛片一区二区| 国产亚洲欧洲997久久综合| 亚洲桃花岛网站| 在线电影国产精品| 欧美在线影院| 一区二区三区高清在线观看| 久久综合中文字幕| 亚洲在线电影| 欧美日韩国内自拍| 亚洲国产精品一区二区久| 国产精品久久久久久久久久久久| 亚洲欧洲三级电影| 国产视频久久网| 亚洲一区二区影院| 亚洲欧洲午夜|