




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
基于XilinxFPGA實現(xiàn)的DDRSDRAM控制器工作過程詳解1引言在高速信號處理系統(tǒng)中,需要緩存高速、大量的數(shù)據(jù),存儲器的選擇與應(yīng)用已成為系統(tǒng)實現(xiàn)的關(guān)鍵所在。DDRSDRAM是一種高速CMOS、動態(tài)隨機(jī)訪問存儲器,它采用雙倍數(shù)據(jù)速率結(jié)構(gòu)來完成高速操作。SDRSDRAM一個時鐘周期只能傳輸一個數(shù)據(jù)位寬的數(shù)據(jù),因此在相同的數(shù)據(jù)總線寬度和工作頻率下,DDRSDRAM的總線帶寬比SDRSDRAM的總線帶寬提高了一倍。XilinxVirtexTM-4FPGA具備ChipSync源同步技術(shù)等優(yōu)勢。它的輸入輸出模塊(IOB)提供了封裝引腳與內(nèi)部可配置邏輯之間的接口,無論是輸入路徑還是輸出路徑都提供了一個可選的SDR和DDR寄存器。VirtexTM-4的IOB專門針對源同步設(shè)計進(jìn)行了優(yōu)化,包括每一位的偏移校正、數(shù)據(jù)的串行化和解串行化、時鐘分頻以及專用的本地時鐘資源等,而且它在每一個I/O模塊中都提供了64-階延遲線。這些特性使得VirtexTM-4FPGA能夠更好的實現(xiàn)DDRSDRAM控制器的邏輯設(shè)計,準(zhǔn)確可靠的捕獲數(shù)據(jù)。實驗板選擇專為DSP應(yīng)用而優(yōu)化的Virtex-4SX35作為DDRSDRAM控制器的實現(xiàn)平臺,選用MicronMT46V8M16P-75ZDDRSDRAM。2DDRSDRAM控制器工作原理DDRSDRAM控制器的主要功能就是完成對DDRSDRAM的初始化,將DDRSDRAM復(fù)雜的讀寫時序轉(zhuǎn)化為用戶簡單的讀寫時序,以及將DDRSDRAM接口的雙時鐘沿數(shù)據(jù)轉(zhuǎn)換為用戶的單時鐘沿數(shù)據(jù),使用戶像操作普通的RAM一樣控制DDRSDRAM;同時,控制器還要產(chǎn)生周期性的刷新命令來維持DDRSDRAM內(nèi)的數(shù)據(jù)而不需要用戶的干預(yù)。該控制器的模塊化表示如圖1。應(yīng)用層接口是DDR控制器與FPGA用戶設(shè)計的接口。對于DDR控制器的用戶來說,只需要了解如何使用應(yīng)用層接口,通過應(yīng)用層接口給DDR控制器發(fā)出指令、數(shù)據(jù),并且接收數(shù)據(jù)。這種模塊化設(shè)計增加了DDR控制器的可移植性,也使用戶使用起來更簡單。要功能是:完成存儲器的初始化,接收并解碼用戶指令然后產(chǎn)生讀、寫、刷新等指令。控制層的邏輯設(shè)計主要是由一個狀態(tài)機(jī)管理的。物理層是直接與DDRSDRAM通信的平臺,它的主要功能是:捕獲DDRSDRAM發(fā)出的數(shù)據(jù)、以及通過輸入輸出緩存發(fā)送所有DDRSDRAM的控制信號、地址信號以及數(shù)據(jù)信號。2.1控制層工作原理控制層主要由一個狀態(tài)機(jī)來控制DDRSDRAM控制器的狀態(tài)轉(zhuǎn)移。狀態(tài)機(jī)如圖2所示。DDRSDRAM上電后必須按照規(guī)定的程序完成初始化的過程。在初始化過程中一定要注意普通模式寄存器與擴(kuò)展模式寄存器的值是否正確。普通模式寄存器用來設(shè)定DDRSDRAM的工作方式,包括突發(fā)長度、突發(fā)類型、CAS潛伏期和工作模式;擴(kuò)展模式寄存器主要實現(xiàn)對DDRSDRAM內(nèi)部DLL的使能和輸出驅(qū)動能力的設(shè)置。在本實驗板中選擇的是MicronMT46V8M16P-75Z型號的DDRSDRAM,該型號芯片CAS潛伏期只能為2或者2.5。初始化完成之后,DDRSDRAM進(jìn)入正常的工作狀態(tài),此時可對存儲器進(jìn)行讀寫和刷新操作。在本設(shè)計中為了計算讀數(shù)據(jù)延遲量引入了一個假讀操作(DummyRead),這將在下一節(jié)中詳細(xì)分析。DDRSDRAM在一對差分時鐘的控制下工作。命令在每個時鐘的上升沿觸發(fā)。隨著數(shù)據(jù)一起傳送的還包括一個雙向的數(shù)據(jù)選通信號DQS,接收方通過該信號來接收數(shù)據(jù)。該選通信號與數(shù)據(jù)相關(guān),其作用類似于一個獨立的時鐘。DQS作為選通信號在讀周期中由DDRSDRAM來產(chǎn)生。讀周期中,DQS與數(shù)據(jù)是邊沿對齊的。讀操作時,DDR控制器采用直接時鐘獲取的方式捕獲數(shù)據(jù)。讀命令觸發(fā)后,數(shù)據(jù)將在CAS延遲之后出現(xiàn)在數(shù)據(jù)總線上。DQS在寫周期中是由DDR控制器產(chǎn)生的。寫周期中,DQS與數(shù)據(jù)是中心對齊的。讀寫操作時序如圖3(DQ指傳輸?shù)臄?shù)據(jù))。在進(jìn)行讀寫操作之前需要先執(zhí)行ACTIVE命令(激活命令),與激活命令一起被觸發(fā)的地址用來選擇將要存取的區(qū)(bank)和頁(或行)。與讀或?qū)懨钜黄鹩|發(fā)的地址位用來選擇突發(fā)存取的起始列單元。在激活指令之前還有一個預(yù)充電(PRECHARGE)操作,預(yù)充電操作關(guān)閉之前進(jìn)行操作的存儲區(qū)或行,此操作之后DDRSDRAM才能對新的區(qū)或者行進(jìn)行讀寫操作。DDRSDRAM需要用自動刷新(AUTOREFRESH)命令來周期性的刷新DDRSDRAM,以保持其內(nèi)部的數(shù)據(jù)不丟失。自動刷新必須在所有區(qū)都空閑的狀態(tài)下才能執(zhí)行。128Mb的DDRSDRAM執(zhí)行自動刷新的周期最大為15.625μs。寫操作是由FPGA向DDRSDRAM寫入數(shù)據(jù),只需按照DDRSDRAM的工作要求發(fā)出相應(yīng)的指令即可,邏輯設(shè)計相對簡單,因此下面我們將詳細(xì)介紹讀操作中的數(shù)據(jù)捕獲技術(shù)。2.2物理層數(shù)據(jù)捕獲技術(shù)及數(shù)據(jù)通道電路物理層的主要功能是獲得DDRSDRAM發(fā)出的數(shù)據(jù)、以及通過輸入輸出緩存發(fā)送所有DDRSDRAM的控制信號、地址信號以及數(shù)據(jù)信號。數(shù)據(jù)捕獲技術(shù)及數(shù)據(jù)通道電路是DDRSDRAM控制器的技術(shù)核心。DDRSDRAM接口是源同步接口,即數(shù)據(jù)與傳輸時鐘是邊沿對齊的。因此,為了在FPGA中可靠捕獲數(shù)據(jù)要么延遲時鐘要么延遲數(shù)據(jù),使數(shù)據(jù)與時鐘中心對齊。本設(shè)計采取直接時鐘數(shù)據(jù)捕獲技術(shù)。所謂直接時鐘數(shù)據(jù)捕獲技術(shù)就是利用DQS信號計算數(shù)據(jù)延遲量,通過延遲數(shù)據(jù)使數(shù)據(jù)中心與FPGA內(nèi)部時鐘沿對齊,然后用該內(nèi)部時鐘直接讀取數(shù)據(jù)。DQS是由DDR發(fā)出的數(shù)據(jù)選通信號,它與FPGA內(nèi)部時鐘頻率相同。此項技術(shù)的關(guān)鍵是確定數(shù)據(jù)的延遲時間。相對于其他的數(shù)據(jù)捕獲技術(shù),這種直接時鐘數(shù)據(jù)捕獲技術(shù)可以應(yīng)用于更高的時鐘頻率,精確性和穩(wěn)定性都高于其他方法。為了得到數(shù)據(jù)應(yīng)該延遲的時間量,首先要對DQS進(jìn)行邊沿檢測。控制器發(fā)出Dummy_rd_en信號(即假讀信號)使DDRSDRAM發(fā)出DQS信號,當(dāng)延遲量計算完畢時,置Dummy_rd_en為低。在XilinxVirtexTM-4FPGA中實現(xiàn)該延遲檢測電路是非常容易的,因為設(shè)計可以直接利用FPGA內(nèi)部的IDELAY與IDELAY_CTRL電路。圖5表示了邊沿檢測以及數(shù)據(jù)通道電路。在該電路中,DQS輸入到IDELAY模塊,延遲量初始化為0,然后延遲量逐次遞增,在這個過程中不斷檢測延遲后的DQS的跳變沿,并將延遲量TAP值記錄下來,以便計算數(shù)據(jù)DQ的延遲量。在圖中可看出,邊沿檢測和控制邏輯發(fā)出DLYRST、DLYCE和DLYINC三個信號來控制IDELAY延遲模塊的工作模式。由于IDELAY模塊的最大延遲階數(shù)為64,且在XilinxVirtexTM-4FPGA中,延遲模塊的精度TIDELAYRESOLUTION為75ps,所以延遲時間最大為75ps*64=4.8ns,因此當(dāng)時鐘頻率低于200MHZ(周期為5ns)時,不可能檢測到兩個跳變沿,此時必須采取適當(dāng)?shù)拇胧﹣慝@得數(shù)據(jù)延遲量。當(dāng)64階延遲量完成時只檢測到一個跳變沿時,我們認(rèn)為數(shù)據(jù)延遲量為檢測到第一個跳變沿時的延遲量加上16,因為四分之一個200MHZ時鐘周期大約為16階延遲量(16*75=1.2ns)即:延遲后的數(shù)據(jù)經(jīng)過IDDR觸發(fā)器分別得到上升沿對應(yīng)的數(shù)據(jù)和下降沿對應(yīng)的數(shù)據(jù),然后再通過異步查找表FIFO使讀進(jìn)FPGA的數(shù)據(jù)與FPGA內(nèi)部時鐘同步方便用戶使用。3控制器實驗結(jié)果及結(jié)論該DDR控制器設(shè)計總共占用751個4輸入LUT,占總LUT資源的2%。另外,設(shè)計還使用了3個DCM。DDR控制器在XilinxISE8.1i編程環(huán)境下實現(xiàn),結(jié)合ModelSimSE
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 設(shè)備維修說明
- 青海省西寧市2025屆九年級下學(xué)期中考二模地理試卷(含答案)
- 自動控制原理第五版 胡壽松課后習(xí)題答案
- 貴州省黔東南州2023-2024學(xué)年八年級下學(xué)期期末考試語文試卷(含答案)
- 財務(wù)會計人員崗位職責(zé)
- 打造獨具特色的文旅商品品牌之路
- 道德與法治(河北卷)(考試版A3)
- 建筑施工特種作業(yè)-建筑電工真題庫-5
- 森林防火管護(hù)題目及答案
- 掃盲運動題目及答案高中
- 遼寧省本溪市(2024年-2025年小學(xué)六年級語文)統(tǒng)編版期末考試((上下)學(xué)期)試卷及答案
- 《PLC光分路器》課件
- 小額貸款公司數(shù)據(jù)安全管理制度
- 護(hù)理學(xué)基礎(chǔ)無菌技術(shù)說課
- 青少年抑郁藥物治療
- 學(xué)校公共設(shè)施設(shè)備的管理制度
- 商混站(商品混凝土公司)安全風(fēng)險分級管控和隱患排查治理雙體系方案全套資料匯編完整版
- 北京師范大學(xué)《數(shù)字圖像處理》2023-2024學(xué)年期末試卷
- GB/T 16288-2024塑料制品的標(biāo)志
- 醫(yī)院培訓(xùn)課件:《肩周炎》
- 安全生產(chǎn)月關(guān)愛生命注意安全
評論
0/150
提交評論