新聞中心

EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 基于FPGA的DDR內(nèi)存條的控制研究與設(shè)計(jì)

基于FPGA的DDR內(nèi)存條的控制研究與設(shè)計(jì)

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

  3 對(duì) SDRAM的控制

  本設(shè)計(jì)中使用的是ALTERA公司的cyclone II系列的EP2C20F484C6。對(duì)條的工作模式設(shè)置為BL=4,CL=3,如圖7為對(duì) SD-RAM的控制模塊框圖。

  其中,Clkin為外部輸入的時(shí)鐘信號(hào),為了使FPGA到 SDRAM的兩對(duì)時(shí)鐘信號(hào)的質(zhì)量盡量好,使用FPGA內(nèi)部的兩個(gè)鎖相環(huán)輸出差分時(shí)鐘信號(hào)。為了保證鎖相環(huán)輸出的兩路差分信號(hào)相位一致,在設(shè)計(jì)PCB時(shí)我們使晶振輸出到FPGA兩個(gè)PLL輸入的布線距離相等,為了保證兩個(gè)鎖相環(huán)輸出信號(hào)到達(dá)DDR SDRAM接口時(shí)相位一致,由FPGA鎖相環(huán)輸出到DDR SDRAM的接口布線長(zhǎng)度相等。

  控制模塊采用的工作模式是按照?qǐng)D2所示的狀態(tài)來跳轉(zhuǎn),上電以后首先是對(duì)DDR SDRAM進(jìn)行初始化,初始化完成以后就可以進(jìn)出等待工作的狀態(tài)。此時(shí)刷新計(jì)數(shù)器開始計(jì)數(shù),等待7.8 us后給出刷新請(qǐng)求,在空閑狀態(tài)時(shí)(IDEL)刷新請(qǐng)求的優(yōu)先級(jí)最高,響應(yīng)刷新請(qǐng)求后執(zhí)行REFR-ESH指令同時(shí)復(fù)位刷新計(jì)數(shù)器。初始化后如果FIF00的讀空標(biāo)志為O說明FIF00中有數(shù)據(jù),此時(shí)可以進(jìn)入到寫狀態(tài)。由于采用的是BL=4的工作狀態(tài),寫操作每次都寫入4個(gè)64位的數(shù)。所以,我們將輸入的數(shù)據(jù)進(jìn)行并位成256位的數(shù),每次寫操作只需要從FIF00中讀出一個(gè)256位的數(shù)。假設(shè)我們采用1OOMHz的時(shí)鐘,每寫4個(gè)64位的數(shù)大概需要10個(gè)時(shí)鐘周期。如果輸入的數(shù)據(jù)位寬為16位,那么由外部傳給FPGA的數(shù)據(jù)率要小于160 MHz。寫操作完成的時(shí)候進(jìn)入空閑狀態(tài),等待刷新標(biāo)志或者讀空標(biāo)志。讀的時(shí)候需要等待系統(tǒng)發(fā)出讀命令(read),然后進(jìn)入讀狀態(tài),讀出的數(shù)據(jù)由Ddrout[127:O]送到FIF01和FIF02中。通過控制FIF01和FIF02的寫請(qǐng)求信號(hào)來實(shí)現(xiàn)將數(shù)據(jù)分別寫入。讀的時(shí)候BL=4每次讀出4個(gè)64位數(shù),執(zhí)行一次讀操作大約需要10個(gè)時(shí)鐘周期。如果輸出的數(shù)據(jù)位寬為16位,那么數(shù)據(jù)由FPGA向外傳輸?shù)乃俾室∮?60 MHzo控制模塊在讀寫條的時(shí)候控制數(shù)據(jù)模塊來實(shí)現(xiàn)數(shù)據(jù)率為時(shí)鐘速度的兩倍,數(shù)據(jù)模塊使用兩個(gè)時(shí)鐘一個(gè)是系統(tǒng)時(shí)鐘一個(gè)是2倍的系統(tǒng)時(shí)鐘。

  因?yàn)镈DR SDRAM的控制相對(duì)復(fù)雜,我們可以使用條的vefilog模型,通過對(duì)內(nèi)存條的vefilog仿真,我們可以知道自己程序的正確性,圖8為modelsim中的仿真波形。如果仿真過程正確,我就可以對(duì)程序進(jìn)行編譯,布局布線,然后下載到FPGA中,由于布局布線的延時(shí),輸出的信號(hào)波形與仿真波形不一致,此時(shí),可以通過調(diào)整FPGA內(nèi)部的鎖相環(huán)來調(diào)整時(shí)序,實(shí)現(xiàn)對(duì)內(nèi)存條的控制。

  4 結(jié)束語(yǔ)

  通過介紹內(nèi)存條的工作原理,以及內(nèi)存條電路設(shè)計(jì)時(shí)的注意事項(xiàng)的介紹,我們可以更合理的實(shí)現(xiàn)FPGA與內(nèi)存條的互連。最后,給出FPGA內(nèi)部對(duì)內(nèi)存條控制的方法,以及給出仿真波形,實(shí)現(xiàn)對(duì)內(nèi)存條的控制。實(shí)現(xiàn)FPGA對(duì)DDRSDRAM內(nèi)存條的控制,可以實(shí)現(xiàn)大容量高速的數(shù)據(jù)存儲(chǔ),在工程中的得到廣泛的應(yīng)用。


上一頁(yè) 1 2 3 下一頁(yè)

關(guān)鍵詞: FPGA DDR 內(nèi)存 SDKAM

評(píng)論


相關(guān)推薦

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

關(guān)閉