<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>
關(guān) 閉

新聞中心

EEPW首頁(yè) > 工控自動(dòng)化 > 設計應用 > 基于VHDL的SDRAM控制器的實(shí)現

基于VHDL的SDRAM控制器的實(shí)現

作者: 時(shí)間:2012-10-29 來(lái)源:網(wǎng)絡(luò ) 收藏

本文引用地址:http://dyxdggzs.com/article/159725.htm

  ADDR為輸入地址端口。將其解析為對應的片選、頁(yè)以及行、列地址。以一條MIT16LSDT6464A內存條為例,其大小為512Mbyte(2 29 byte)。數據位寬為64bit(8byte),則地址線(xiàn)ADDR應為26根??梢赃@樣映射地址:ADDR[25]對應內存芯片組號;ADDR[24:23]對應頁(yè)號;ADDR[22:10]對應行號;ADDR[9:0]對應列號。

DATAIN為寫(xiě)入數據端口,64bit位寬。

  DATAOUT為讀出數據端口,64bit位寬。

  RD_OE為讀出數據使能端口,當其為1時(shí),表示從下一個(gè)時(shí)鐘起,數據將依次出現在DATAOUT口上。

  WR_OE為寫(xiě)入數據使能端口,當其為1時(shí),寫(xiě)入數據應該依次出現在DATAIN口上。

  CMD[2:0]為命令輸入端口,分別表示讀、寫(xiě)內存等待操作。其中,CMD=“000”表示無(wú)操作,內存條交給管理,定其完成刷新工作;REFRESH命令由外部邏輯指定特刷新的內存芯片信號,組號由ADDR的低位給出;LOAD_MODE命令執行內存條工作寄存器初始化工作,初始化值由DATAIN的低13位決定,內存芯片組號同樣由ADDR的低位給出;同理,ADDR的低位也決定了預充電操作所對應的內存芯片組號。

  CMDACK為命令應答端口,表示命令已經(jīng)被執行,使外部邏輯可以向發(fā)出下一個(gè)動(dòng)作。

  4.2 狀態(tài)機

  圖3是控制器的狀態(tài)轉移圖。狀態(tài)圖中的各個(gè)狀態(tài)內均包含一系列的子狀態(tài)轉移(對內存條發(fā)出連續命令),每個(gè)子狀態(tài)完成一個(gè)功能操作。初始化操作包括前面介紹的內存條初始化全過(guò)程,工作寄存器的默認值在程序中指定。以后可以通過(guò)LOAD_MODE命令改變內存條的工作模式。初始化結束后,內存條進(jìn)入Idel狀態(tài),刷新計數器開(kāi)始工作,控制器開(kāi)始響應外部邏輯的操作請求。

圖3是SDRAM控制器的狀態(tài)轉移圖

  刷新計數器操作是一個(gè)獨立的進(jìn)程(process)。刷新計數器的初值由內存芯片要求、內存條個(gè)數和控制器工作頻率共同決定。例如,在本次設計中,所采用的MT48LC32M8A2內存芯片要求在64ms內夏至少刷新8196次。而MIT16LSDT6464A型內存條共有兩組內存芯片,也就是要求在64ms內要發(fā)出8196×2條自刷新(AUTO REFRESH)指令。系統工作時(shí)鐘為46.66MHz,因此控制單條MIT16LSDT6464A時(shí),刷新計數器初值至多為(64ms/8196/2)×6、、46.66MHz,即182.開(kāi)始工作后,每當刷新計數器值減為0,便依次向內存芯片組發(fā)出刷新命令,保證中的數據不丟失。刷新請求是內存請求;讀和寫(xiě)操作是外部請求。在Idel狀態(tài)中有請求仲裁邏輯,當內部和外部請求同時(shí)出現時(shí),優(yōu)先保證內部請求,狀態(tài)轉移至刷新操作。當刷新操作結束時(shí),重新返回Idel狀態(tài),開(kāi)始響應外部請求。響應外部請求后,應答信號CMDBAK出現正脈沖。它通知外部邏輯,請求已經(jīng)被響應,可以撤銷(xiāo)請求。在刷新操作狀態(tài)中,也有許數器計數,其大小等于控制器管理的內存芯片信號。記錄并判斷此次刷新操作所對應的內存芯片的組號,產(chǎn)生相應的片選信號。

  響應讀、寫(xiě)請求后,狀態(tài)從Idel轉移到讀、寫(xiě)狀態(tài)。同時(shí)讀、寫(xiě)地址和寫(xiě)入的數據鎖存至控制器??刂破饔勺x寫(xiě)地址解析出CS信號、頁(yè)地址、行地址、列地址。向內存條發(fā)出一系列命令(ACTIVE,READ/WRITE with AUTO PRECHARGE),完成讀寫(xiě)操作,為了簡(jiǎn)化,此控制器向SDRAM發(fā)出的都是帶有AUTO PRECHARGE的讀、寫(xiě)指令,然后由SDRAM內部邏輯自動(dòng)在讀、寫(xiě)過(guò)程末期發(fā)出PRECHARGE指令(在發(fā)READ/WRITE指令時(shí),地址線(xiàn)A10賦值1,打開(kāi)AUTO PRECHARGE功能)。圖4和圖5分別是利用該控制器完成讀、寫(xiě)操作的時(shí)序圖。讀操作的CAS延遲為兩個(gè)時(shí)鐘。

控制器完成讀操作的時(shí)序圖

控制器完成寫(xiě)操作的時(shí)序圖

  該SDRAM控制器在中頻數據海量存儲系統中已得到應用。數據接收邏輯將接收到的中頻采樣數據整理后(拼接成64bit),通過(guò)SDRAM控制器存入SDRAM陣列。存滿(mǎn)后,數據輸出邏輯將中頻數據通過(guò)SDRAM控制器從內存條中取出,傳輸至上位機。其代碼在A(yíng)TERA公司的FPGA--EP1C6Q240中通過(guò)了Quartus II的仿真、綜合和布局、布線(xiàn)。占用499個(gè)logic cellk,消耗了8%的邏輯資源。留有豐富的資源可提供給其它邏輯單元使用。

  上面介紹了SDRAM的基本工作原理和一種簡(jiǎn)單的通用SDRAM控制器的。SDRAM的控制機制比較復雜,具有多種突發(fā)讀、寫(xiě)方式和工作模式(詳細內容請參考SDRAM的數據手冊)。但是,可以根據應用,其中的一個(gè)子集(基本讀、寫(xiě)、刷新操作)來(lái)滿(mǎn)足實(shí)際系統的需要。用SDRAM實(shí)現大容量的高速數據緩存具有明顯的優(yōu)勢,使用可編程器件實(shí)現SDRAM控制器則使之具有更高的靈活性,其應用前景廣闊。


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

關(guān)鍵詞: 實(shí)現 控制器 SDRAM VHDL 基于

評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>