當(dāng)前位置:首頁 > 嵌入式 > 嵌入式教程
[導(dǎo)讀]基于SDRAM文件結(jié)構(gòu)存儲(chǔ)方式的數(shù)據(jù)緩存系統(tǒng)

O 引言

  面對(duì)不同的應(yīng)用場(chǎng)景,原始采樣數(shù)據(jù)可能包含多種不同樣式的信號(hào),這給傳統(tǒng)基于連續(xù)存儲(chǔ)方式的數(shù)據(jù)緩存系統(tǒng)帶來了挑戰(zhàn)。除此之外,由于對(duì)不同信號(hào)的處理往往需要不同的數(shù)據(jù)幀結(jié)構(gòu),緩存系統(tǒng)的設(shè)計(jì)需要保存原始采樣數(shù)據(jù)并能夠?qū)崿F(xiàn)數(shù)據(jù)的重組幀,以滿足不同處理需求。

      針對(duì)以上問題,本文提出了一種基于文件結(jié)構(gòu)存儲(chǔ)方式的


 

  2 系統(tǒng)工作原理

  2.1 文件結(jié)構(gòu)的存儲(chǔ)方式

  所謂文件結(jié)構(gòu)指的是,將幀頭與其所對(duì)應(yīng)的數(shù)據(jù)分區(qū)存儲(chǔ),在存儲(chǔ)時(shí)將存儲(chǔ)數(shù)據(jù)的首地址添加到幀頭信息中,在讀出時(shí),先讀取幀頭找到數(shù)據(jù)的首地址,然后加上系統(tǒng)給定的偏移地址算出讀取的起始地址,從該地址開始順序讀取要求長度(小于等于幀長)的數(shù)據(jù),在送往后端系統(tǒng)時(shí)更新幀頭信息,后端系統(tǒng)收到數(shù)據(jù)無需做預(yù)處理直接進(jìn)行計(jì)算即可。圖2是2種存儲(chǔ)結(jié)構(gòu)的比較。

  

 

  基于文件結(jié)構(gòu)的存儲(chǔ)方式便于對(duì)數(shù)據(jù)進(jìn)行管理與操作,功能擴(kuò)展容易。例如有些處理只對(duì)數(shù)據(jù)的幀頭信息進(jìn)行相關(guān)操作,基于文件結(jié)構(gòu)的存儲(chǔ)模式可以很方便地支持這種工作模式,只需對(duì)緩存介質(zhì)的幀頭區(qū)進(jìn)行操作,而傳統(tǒng)的設(shè)計(jì)則很難滿足這種需求,因此新的設(shè)計(jì)極大地提高了系統(tǒng)的靈活性。[!--empirenews.page--]

  2.2 數(shù)據(jù)重組幀的實(shí)現(xiàn)

  在設(shè)計(jì)上,用SDRAM的BANK0(BANK地址“00")和BANKl(BANK地址“01”)存儲(chǔ)原始數(shù)據(jù),BANK2(BANK地址“10”)存儲(chǔ)要送往后端計(jì)算的數(shù)

  據(jù),BANK3(BANK地址“11”)存儲(chǔ)數(shù)據(jù)的幀頭信息。系統(tǒng)在接收到數(shù)據(jù)重組幀命令后,按照要求抽取,幀數(shù),幀長和幀間隔從低BANK區(qū)讀取原始數(shù)據(jù)送入數(shù)據(jù)重組幀模塊形成新的數(shù)據(jù)幀結(jié)構(gòu),然后將新的數(shù)據(jù)幀結(jié)構(gòu)按照文件結(jié)構(gòu)存儲(chǔ)到高BANK區(qū)中。其實(shí)現(xiàn)框圖如圖3所示。

  

 

  3 控制模塊的結(jié)構(gòu)化狀態(tài)機(jī)設(shè)計(jì)

  在系統(tǒng)架構(gòu)上采用了結(jié)構(gòu)化狀態(tài)機(jī)的設(shè)計(jì)方法,通過分層有限狀態(tài)機(jī)實(shí)現(xiàn)了主控狀態(tài)機(jī)與具體操作控制狀態(tài)機(jī)的分離,使設(shè)計(jì)結(jié)構(gòu)清晰,劃分合理。降低了設(shè)計(jì)的復(fù)雜性,同時(shí)使系統(tǒng)更具有通用性。

  3.1 高層工作模式主控狀態(tài)機(jī)設(shè)計(jì)

  該緩存系統(tǒng)有3種工作模式:寫模式,讀模式和數(shù)據(jù)重組幀模式。其狀態(tài)轉(zhuǎn)移圖如圖4所示。

  

[!--empirenews.page--]

 

  系統(tǒng)在空閑狀態(tài)等待SDRAM初始化完成,當(dāng)SDRAM完成初始化以后進(jìn)入準(zhǔn)備狀態(tài),表示系統(tǒng)可以接收命令,在收到寫命令后進(jìn)入寫工作模式,低層寫輔助控制模塊激活,當(dāng)完成寫操作命令后產(chǎn)生一寫完成標(biāo)志信號(hào),反饋回主控系統(tǒng)促使主控系統(tǒng)完成狀態(tài)跳轉(zhuǎn)回到準(zhǔn)備狀態(tài)等待下一次命令,收到讀取命令后系統(tǒng)進(jìn)入讀工作模式,低層讀輔助控制模塊開始工作當(dāng)完成讀取操作后產(chǎn)生一讀完成標(biāo)志信號(hào),反饋回主控系統(tǒng)使其回到準(zhǔn)備狀態(tài)等待命令,同樣系統(tǒng)收到數(shù)據(jù)重組幀命令后進(jìn)人數(shù)據(jù)重組幀模式,低層重組幀輔助控制模塊開始工作完成重組幀任務(wù)后產(chǎn)生標(biāo)志信號(hào)控制主控狀態(tài)機(jī)再次回到準(zhǔn)備狀態(tài),等待下一次命令。

  這種結(jié)構(gòu)化狀態(tài)機(jī)的設(shè)計(jì),層次劃分合理清晰,工作模式的切換只在主控狀態(tài)機(jī)中實(shí)現(xiàn),各低層輔助控制模塊僅僅實(shí)現(xiàn)其特定的功能,完全沒有交互。因此這種設(shè)計(jì)可以很方便地進(jìn)行功能擴(kuò)展,以后系統(tǒng)要增加新的工作模式,只需再加入一個(gè)狀態(tài),并單獨(dú)設(shè)計(jì)其輔助控制模塊即可,無需對(duì)原有工作模式進(jìn)行改動(dòng)。同時(shí),這種分層設(shè)計(jì)符合模塊化設(shè)計(jì)的思想,降低了設(shè)計(jì)的復(fù)雜性,易于調(diào)試。

  3.2 低層寫輔助控制模塊的設(shè)計(jì)

  寫輔助控制模塊用來實(shí)現(xiàn)對(duì)原始數(shù)據(jù)和第1次計(jì)算數(shù)據(jù)基于文件結(jié)構(gòu)的存儲(chǔ)。為了提高系統(tǒng)效率,第1次計(jì)算所需的數(shù)據(jù)和原始數(shù)據(jù)同時(shí)存儲(chǔ)。其總體設(shè)計(jì)框圖如圖5所示。

  

 

  寫輔助控制模塊在主控狀態(tài)機(jī)進(jìn)入寫工作模式時(shí)激活,通過將原始數(shù)據(jù)分為2路,一路進(jìn)入原始數(shù)據(jù)緩存控制模塊實(shí)現(xiàn)對(duì)原始數(shù)據(jù)的緩存,當(dāng)原始數(shù)據(jù)的數(shù)據(jù)量積累到SDRAM一次突發(fā)寫所需長度時(shí),該控制模塊發(fā)出寫標(biāo)志信號(hào)通知寫模式控制狀態(tài)機(jī),寫模式控制狀態(tài)機(jī)響應(yīng)寫標(biāo)志信號(hào),向SDRAM驅(qū)動(dòng)控制器發(fā)出寫指令字控制SDRAM將原始數(shù)據(jù)寫入SDRAM的原始數(shù)據(jù)區(qū);另一路進(jìn)入1st計(jì)算數(shù)據(jù)構(gòu)造與緩存控制模塊,該模塊用來完成1st計(jì)算數(shù)據(jù)的幀頭與數(shù)據(jù)的構(gòu)造和緩存,當(dāng)幀頭構(gòu)造完畢時(shí),通知寫模式控制狀態(tài)機(jī),將幀頭(包含數(shù)據(jù)存儲(chǔ)首地址信息)寫入到SDRAM的幀頭區(qū)中,同時(shí)當(dāng)新數(shù)據(jù)量達(dá)到一次突發(fā)寫入時(shí),將新數(shù)據(jù)寫入SDRAM的計(jì)算數(shù)據(jù)區(qū)中,直到將所有數(shù)據(jù)都寫入到SDRAM的對(duì)應(yīng)區(qū)內(nèi),寫模式控制狀態(tài)機(jī)發(fā)出寫完成標(biāo)志信號(hào),反饋給高層主控狀態(tài)機(jī)。

  3.3 低層讀輔助控制模塊的設(shè)計(jì)

  讀輔助控制模塊,接收讀指令字,該指令字包括幀數(shù)、幀長和偏移地址。幀數(shù)表征著本次命令要從SDRAM中讀取多少幀數(shù)據(jù),幀長表示每幀數(shù)據(jù)要讀取的長度(按采樣點(diǎn)數(shù)算),偏移地址控制對(duì)數(shù)據(jù)的移位讀操作。按照指令要求從SDRAM的高BANK區(qū),讀出數(shù)據(jù)送往后端。圖6是其總體設(shè)計(jì)框圖。

  

 

  讀輔助控制模塊在主控狀態(tài)機(jī)進(jìn)入讀工作模式開始工作,它先控制SDRAM驅(qū)動(dòng)器從SDRAM幀頭區(qū)中讀取一個(gè)幀頭,送入緩存及幀頭更新模塊,該模塊一方面按照指令字更新幀頭信息中的數(shù)據(jù)到達(dá)與結(jié)束時(shí)間,另一方面從幀頭信息中找到本幀數(shù)據(jù)的存儲(chǔ)首地址然后加上讀指令字中的偏移地址算出本次對(duì)數(shù)據(jù)讀操作的起始地址,該地址反饋給讀模式控制狀態(tài)機(jī),控制SDRAM從該地址開始順序讀出數(shù)據(jù),完成一幀數(shù)

  據(jù)的讀取操作送往數(shù)據(jù)緩存模塊,重復(fù)以上操作直到完成讀指令任務(wù),讀模式控制狀態(tài)機(jī)發(fā)出讀完成標(biāo)志信號(hào),反饋給高層主控狀態(tài)機(jī)。

  3.4 低層數(shù)據(jù)重組幀輔助控制模塊的設(shè)計(jì)

  數(shù)據(jù)重組幀輔助控制模塊,接收重組幀指令字,該指令字包括重組幀幀數(shù)、幀長、幀間隔以及抽取因子,控制SDRAM讀取原始數(shù)據(jù),生成新的需要的數(shù)據(jù)幀結(jié)構(gòu),并按文件結(jié)構(gòu)將其寫到SDRAM的計(jì)算數(shù)據(jù)區(qū)中。其總體設(shè)計(jì)框圖7所示。

  

[!--empirenews.page--]

 

  數(shù)據(jù)重組幀輔助控制模塊在主控狀態(tài)機(jī)進(jìn)入重組幀工作模式時(shí)開始工作,新數(shù)據(jù)幀結(jié)構(gòu)生成及緩存模塊先構(gòu)造第一幀數(shù)據(jù)的幀頭信息,當(dāng)幀頭構(gòu)造完畢后,它向重組幀模式控制狀態(tài)機(jī)發(fā)出幀頭完畢信號(hào),狀態(tài)機(jī)收到信號(hào)后向SDRAM發(fā)出寫命令將新的數(shù)據(jù)幀頭寫入到幀頭區(qū)中,然后它按照重組幀指令字的要求從SDRAM的原始數(shù)據(jù)區(qū)讀出原始數(shù)據(jù)送往新數(shù)據(jù)生成模塊,當(dāng)新數(shù)據(jù)的數(shù)據(jù)量達(dá)到一次突發(fā)寫長度時(shí),再控制SDRAM將新的數(shù)據(jù)寫入到SDRAM的重組幀數(shù)據(jù)區(qū)中,直到將一幀新的數(shù)據(jù)都存儲(chǔ)到SDRAM中,記錄此時(shí)的寫地址并將其作為下一幀數(shù)據(jù)的存儲(chǔ)首地址加入到下一幀幀頭信息中,并發(fā)出構(gòu)造第2幀幀頭的命令,等待第2幀幀頭完畢標(biāo)志,重復(fù)上面的操作,直到完成要求的重組幀指令。完

  成操作后重組幀模式控制狀態(tài)機(jī)發(fā)出重組幀完成標(biāo)志信號(hào),反饋給高層主控狀態(tài)機(jī)。

  4 硬件平臺(tái)及實(shí)測(cè)結(jié)果

  在xilinx的開發(fā)工具ISE環(huán)境下完成了系統(tǒng)的整體設(shè)計(jì)與仿真,利用xilinx公司的xc2v3000-4fg676FPGA芯片和MICRONE公司的MT48LC32M1 6A2SDRAM芯片搭建了硬件平臺(tái),并進(jìn)行測(cè)試。其實(shí)測(cè)結(jié)果如圖8所示。

  

 

  主控狀態(tài)機(jī)接收上層的控制命令(寫命令、讀命令和重組幀命令)分別啟動(dòng)寫工作模式、讀工作模式和重組幀工作模式;低層各控制模塊在完成任務(wù)時(shí)將完成標(biāo)志(寫完成標(biāo)志、讀完成標(biāo)志和重組幀完成標(biāo)志)反饋給主控狀態(tài)機(jī)控制其跳轉(zhuǎn)到就緒狀態(tài)繼續(xù)等待下次命令。結(jié)果證明該緩存系統(tǒng)實(shí)現(xiàn)了預(yù)定功能,可以對(duì)數(shù)據(jù)進(jìn)行更方便的操作與管理。

  5 結(jié)語

  本文提出一種基于文件結(jié)構(gòu)存儲(chǔ)方式的新數(shù)據(jù)緩存系統(tǒng),利用FPGA設(shè)計(jì)結(jié)構(gòu)化狀態(tài)機(jī)通過對(duì)SDRAM的讀寫控制,完成了具有數(shù)據(jù)重組幀功能的緩存系統(tǒng)設(shè)計(jì)。系統(tǒng)具有速度快,可靠性好,靈活性強(qiáng),功能擴(kuò)展容易的優(yōu)點(diǎn)。該系統(tǒng)已應(yīng)用于實(shí)際項(xiàng)目試驗(yàn),在基于實(shí)時(shí)復(fù)雜信號(hào)處理的緩存系統(tǒng)中有很好的應(yīng)用前景。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉