0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

采用VHDL語言實現(xiàn)SDRAM與雙口RAM的數(shù)據(jù)傳輸系統(tǒng)設(shè)計

電子設(shè)計 ? 來源:電子技術(shù)應(yīng)用 ? 作者:沙燕萍,曾烈光 ? 2020-06-01 07:08 ? 次閱讀

RAM(隨機存取存儲器是一種在電子系統(tǒng)中應(yīng)用廣泛的器件,通常用于數(shù)據(jù)和程序的緩存。隨著半導(dǎo)體工業(yè)的發(fā)展,RAM獲得了飛速的發(fā)展,從RAM、DRAM(Dynamic RAM,即動態(tài)RAM)發(fā)展到SDRAM(Synchronous Dynamic RAM,即同步動態(tài)RAM),RAM的容量越來越大、速度越來越高,可以說存儲器的容量和速度已經(jīng)成為半導(dǎo)體工業(yè)水平的標(biāo)志。

1、任務(wù)背景

SDRAM具有大容量和高速的優(yōu)點,目前其存取速度可以達(dá)到100~133MHz,單片容量可以達(dá)到64Mbit或更高,因此在需要高速、大容量存儲器的系統(tǒng)中得到廣泛應(yīng)用,如應(yīng)用在目前的計算機內(nèi)存中。但是SDRAM的控制比較復(fù)雜,其接口不能直接與目前廣泛應(yīng)用的普通微處理器例如MCS-51系列、MOTOROLA 68000系列連接,這樣就限制了SDRAM在微處理器系統(tǒng)中的應(yīng)用。

我們的任務(wù)是設(shè)計一個通用微處理器,它要具有語音、數(shù)據(jù)、圖像等多種處理功能,并具有RS232、USB等多種接口,另外由于多個通道的數(shù)據(jù)都需要進(jìn)行緩存和處理,因此高速大容量的緩存是此系統(tǒng)必須的,所以選用了SDRAM作為緩存器件。來自多個輸入通道的數(shù)據(jù)在采集后需要暫時存儲在SDRAM中,處理后的數(shù)據(jù)也需要存儲在SDRAM中,再輸出到輸出通道中。在SDRAM與多個輸入輸出通道之間,采用多個雙口RAM作為接口器件。輸入通道采集的數(shù)據(jù)首先存儲在雙口RAM中,采集滿后,通過若干條指令將RAM中的數(shù)據(jù)轉(zhuǎn)移到SDRAM中的一定位置中,將SDRAM中的數(shù)據(jù)轉(zhuǎn)移到RAM中也只需要若干條指令來完成。這樣通過幾條指令來設(shè)置RAM起始地址、SDRAM起始地址、傳送數(shù)據(jù)長度、傳送數(shù)據(jù)方向之后,SDRAM與RAM之間數(shù)據(jù)傳送就完全可以通過硬件實現(xiàn),不必占用微處理器的指令時間。

2、SDRAM簡介

SDRAM具有多種工作模式,內(nèi)部操作是一個非常復(fù)雜的狀態(tài)機。SDRAM的管腳分為以下幾類:

(1) 控制信號:包括片選、時鐘、時鐘有效、行/列地址選擇、讀寫選擇、數(shù)據(jù)有效;

(2) 地址:時分復(fù)用管腳,根據(jù)行/列地址選擇管腳控制輸入地址為行地址或列地址;

(3) 數(shù)據(jù):雙向管腳,受數(shù)據(jù)有效控制;

根據(jù)控制信號和地址輸入,SDRAM包括多種輸入命令:① 模式寄存器設(shè)置命令;② 激活命令;③ 預(yù)充命令;④寫命令;⑤ 讀命令;⑥自動刷新命令;⑦ 自我刷新命令;⑧突發(fā)停止命令;⑨ 空操作命令。

根據(jù)輸入命令,SDRAM狀態(tài)在內(nèi)部狀態(tài)間轉(zhuǎn)移。內(nèi)部狀態(tài)包括:①模式寄存器設(shè)置狀態(tài);②激活狀態(tài);③預(yù)充狀態(tài);④寫狀態(tài);⑤讀狀態(tài);⑥自動刷新狀態(tài);⑦自我刷新狀態(tài);⑧節(jié)電狀態(tài)。

3、SDRAM接口狀態(tài)機設(shè)計

根據(jù)系統(tǒng)的要求,采用固定型號SDRAM,我們對SDRAM的操作進(jìn)行了以下簡化:

(1)不考慮隨機存取模式,只采用突發(fā)讀寫數(shù)據(jù)模式,固定突發(fā)數(shù)據(jù)長度為2;

(2)固定SDRAM讀命令輸入到數(shù)據(jù)輸出延時時鐘周期為2;

(3)刷新模式僅采用自我刷新模式,不采用自動刷新模式;

(4)SDRAM的初始化、節(jié)電模式由微處理器控制;

(5)SDRAM為16位數(shù)據(jù)總線,RAM為32位數(shù)據(jù)總線,SDRAM進(jìn)行一次突發(fā)操作,RAM進(jìn)行一次讀寫操作,以實現(xiàn)速度匹配;

(6)SDRAM和RAM讀寫地址采用遞增模式,連續(xù)變化。

其中,初始化、自我刷新、電源關(guān)斷、讀操作、寫操作、預(yù)充等狀態(tài)又分別各由一組子狀態(tài)組成。

為充分利用SDRAM的高速存取特性,讀、寫時序必須仔細(xì)設(shè)計,應(yīng)基本可以實現(xiàn)每個時鐘周期進(jìn)行一次數(shù)據(jù)存取。如下圖所示。

采用VHDL語言實現(xiàn)SDRAM與雙口RAM的數(shù)據(jù)傳輸系統(tǒng)設(shè)計

3.1 SDRAM讀操作時序設(shè)計

當(dāng)數(shù)據(jù)轉(zhuǎn)移方向為從SDRAM到雙口RAM時,如果SDRAM讀操作行地址未發(fā)生變化,可以滿足每時鐘周期輸出一次數(shù)據(jù)的高速操作。但是當(dāng)SDRAM行地址發(fā)生變化時,必須返回預(yù)充狀態(tài),由于從SDRAM的讀命令輸入到SDRAM數(shù)據(jù)輸出之間有2個時鐘周期的延時,所以判斷下一讀操作的行地址是否發(fā)生變化必須提前兩個周期判斷。如下圖所示。

3.2 SDRAM寫操作時序設(shè)計

當(dāng)數(shù)據(jù)轉(zhuǎn)移方向為從雙口RAM到SDRAM時,如果SDRAM寫操作行地址未發(fā)生變化,可以滿足每時鐘周期寫入一次數(shù)據(jù)的高速操作。但是當(dāng)SDRAM行地址發(fā)生變化時,必須返回預(yù)充狀態(tài),由于從SDRAM的寫命令輸入到SDRAM數(shù)據(jù)輸入之間沒有延時,所以判斷下一寫操作的行 地址是否發(fā)生變化無需提前判斷,因此寫操作狀態(tài)轉(zhuǎn)移圖比讀操作部分簡單。

在所設(shè)計的讀、寫操作時序中,SDRAM地址、數(shù)據(jù)、控制信號和RAM部分的地址、數(shù)據(jù)、讀寫控制信號均由有限狀態(tài)機產(chǎn)生,因此在狀態(tài)轉(zhuǎn)移過程中還必須仔細(xì)考慮RAM部分輸出控制信號的時序關(guān)系。

4、VHDL實現(xiàn)

硬件描述語言VHDL(Very=high Speed IC HARDWARE DESCRIPTION Language)是一種應(yīng)用于電路設(shè)計的高層次描述語言,具有行為級、寄存器傳輸級和門級等多層次描述,并且具有簡單、易讀、易修改和與工藝無關(guān)等優(yōu)點。目前VHDL語言已經(jīng)得到多種EDA工具的支持,綜合工具得到迅速發(fā)展,VHDL語言的行為級綜合也已經(jīng)得到支持和實現(xiàn),因此利用VHDL語言進(jìn)行電路設(shè)計可以節(jié)約開發(fā)成本,縮短周期。在VHDL語言輸入中也有多種形式,例如可以支持直接由狀態(tài)轉(zhuǎn)移圖生成VHDL語言。因此在設(shè)計SDRAM狀態(tài)轉(zhuǎn)移圖后,可以直接產(chǎn)生VHDL程序,在功能仿真正確后,可以進(jìn)行綜合、FPGA布局布線和后仿真。

以上介紹了一種應(yīng)用于通用微處理器系統(tǒng)中的SDRAM與雙口RAM之間的數(shù)據(jù)轉(zhuǎn)移接口控制電路,由VHDL語言設(shè)計,用XILINX公司4000系列FPGA實現(xiàn),目前該電路硬件實現(xiàn)和微處理器系統(tǒng)已經(jīng)通過驗證,證明可將SDRAM作為高速、大容量存儲器應(yīng)用在簡單電子系統(tǒng)中。

責(zé)任編輯:gt


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • SDRAM
    +關(guān)注

    關(guān)注

    7

    文章

    423

    瀏覽量

    55230
  • 存儲器
    +關(guān)注

    關(guān)注

    38

    文章

    7492

    瀏覽量

    163854
  • vhdl
    +關(guān)注

    關(guān)注

    30

    文章

    817

    瀏覽量

    128141
收藏 人收藏

    評論

    相關(guān)推薦

    基于VHDLSDRAM接口設(shè)計

    介紹了一種應(yīng)用于通用微處理器系統(tǒng)中的SDRAMRAM之間的數(shù)據(jù)轉(zhuǎn)移接口控制電路,由
    發(fā)表于 11-11 09:43 ?1581次閱讀
    基于<b class='flag-5'>VHDL</b>的<b class='flag-5'>SDRAM</b>接口設(shè)計

    基于端口RAMDSP系統(tǒng)搭建

    最近再做一個CPU板子,需要搭建一個DSP系統(tǒng),它們之間的數(shù)據(jù)傳輸通過
    發(fā)表于 05-04 13:00

    基于SDRAM的u***與pc之間數(shù)據(jù)傳輸資料

    請問各位大神有沒有基于SDRAM的u***與pc之間數(shù)據(jù)傳輸資料啊,急用!
    發(fā)表于 11-27 08:30

    VHDL語言實現(xiàn)多DSP局部總線與VME總線接口設(shè)計

    ;write狀態(tài)VME主機正在向RAM寫入數(shù)據(jù);read狀態(tài)表示VME主機正在從
    發(fā)表于 04-12 07:00

    SDRAMRAM數(shù)據(jù)轉(zhuǎn)移接口控制電路

    和后仿真。以上介紹了一種應(yīng)用于通用微處理器系統(tǒng)中的SDRAMRAM之間的數(shù)據(jù)轉(zhuǎn)移接口控制電
    發(fā)表于 06-10 05:00

    如何采用FPGA和CMOS數(shù)字傳感器實現(xiàn)圖像數(shù)據(jù)傳輸的圖像監(jiān)測系統(tǒng)?

    本文提出一種采用FPGA和CMOS數(shù)字傳感器實現(xiàn)前端數(shù)據(jù)采集、利用單片機進(jìn)行圖像鑒別和壓縮、通過以太網(wǎng)控制器實現(xiàn)圖像數(shù)據(jù)傳輸的圖像監(jiān)測
    發(fā)表于 05-26 06:58

    數(shù)據(jù)傳輸的通信系統(tǒng)設(shè)計

    本文主要針對單片機在有線數(shù)據(jù)傳輸方面的應(yīng)用,介紹了一種基于單片機MSP430 實現(xiàn)的MODEM 的數(shù)據(jù)傳輸系統(tǒng)。方案采用一個嵌入式的MODE
    發(fā)表于 06-13 13:38 ?21次下載

    基于FPGA的RAM實現(xiàn)及應(yīng)用

      為了在高速采集時不丟失數(shù)據(jù),在數(shù)據(jù)采集系統(tǒng)和CPU之間設(shè)置一個數(shù)據(jù)暫存區(qū)。介紹
    發(fā)表于 02-11 11:20 ?69次下載

    基于USB2.0的紅外數(shù)據(jù)傳輸系統(tǒng)的設(shè)計與實現(xiàn)

    基于USB2.0的紅外數(shù)據(jù)傳輸系統(tǒng)的設(shè)計與實現(xiàn) 摘要:針對有線傳輸的缺點或不足,為避免經(jīng)常插拔接口造成測試儀器損壞,設(shè)計基于USB2.0的紅外數(shù)據(jù)
    發(fā)表于 03-13 09:56 ?1630次閱讀
    基于USB2.0的紅外<b class='flag-5'>數(shù)據(jù)傳輸</b><b class='flag-5'>系統(tǒng)</b>的設(shè)計與<b class='flag-5'>實現(xiàn)</b>

    基于PCI總線的數(shù)據(jù)傳輸系統(tǒng)

    微控制器的24V接口工業(yè)控制應(yīng)用,本文主要提供一種基于PCI總線的數(shù)據(jù)傳輸系統(tǒng)設(shè)計方案,其中RAM起橋梁作用,完成上位機與外圍主控單元之
    發(fā)表于 04-25 11:41 ?1683次閱讀
    基于PCI總線的<b class='flag-5'>數(shù)據(jù)傳輸</b><b class='flag-5'>系統(tǒng)</b>

    SDRAM接口的VHDL設(shè)計方案

    SDRAM 以其高速和大容量的優(yōu)點獲得了極大的應(yīng)用,但是其接口與目前廣泛應(yīng)用的微處理器系統(tǒng)不兼容,介紹了用 VHDL 語言實現(xiàn)SDRAM
    發(fā)表于 06-01 15:29 ?57次下載
    <b class='flag-5'>SDRAM</b>接口的<b class='flag-5'>VHDL</b>設(shè)計方案

    SOPC實現(xiàn)的PCI總線高速數(shù)據(jù)傳輸系統(tǒng)

    本文提出一種采用可編程片上系統(tǒng)SOPC實現(xiàn)偵察接收機PCI總線高速數(shù)據(jù)傳輸系統(tǒng)的設(shè)計方案。
    發(fā)表于 02-10 11:20 ?1480次閱讀
    SOPC<b class='flag-5'>實現(xiàn)</b>的PCI總線高速<b class='flag-5'>數(shù)據(jù)傳輸</b><b class='flag-5'>系統(tǒng)</b>

    ARM實現(xiàn)無線數(shù)據(jù)傳輸系統(tǒng)

    介紹一種基于ARM微控制器來實現(xiàn)無線分布式的數(shù)據(jù)傳輸系統(tǒng)。網(wǎng)絡(luò)節(jié)點硬件主要使用NXP公司的LPC1766作為微控制器、Nordic公司的nRF905作為射頻芯片。軟件以C語言和匯編
    發(fā)表于 02-16 17:09 ?111次下載
    ARM<b class='flag-5'>實現(xiàn)</b>無線<b class='flag-5'>數(shù)據(jù)傳輸</b><b class='flag-5'>系統(tǒng)</b>

    DDR SDRAM是擁有著雙倍數(shù)據(jù)傳輸率的SDRAM

    DDR SDRAM是具有雙倍數(shù)據(jù)傳輸率的SDRAM,其數(shù)據(jù)傳輸速度為系統(tǒng)時鐘頻率的兩倍,由于速度增加,其
    發(fā)表于 07-16 15:44 ?2256次閱讀

    基于RAM和SN74LVTH245A芯片實現(xiàn)長距離數(shù)據(jù)傳輸系統(tǒng)的設(shè)計

    +3.3V;由于差分驅(qū)動與接收芯片的傳輸方向是單向的,而系統(tǒng)要求雙向數(shù)據(jù)傳輸,對16位數(shù)據(jù)總線的高8位和低8位分別進(jìn)行單向驅(qū)動與接收;利用本方案所
    的頭像 發(fā)表于 03-19 11:35 ?3956次閱讀
    基于<b class='flag-5'>雙</b><b class='flag-5'>口</b><b class='flag-5'>RAM</b>和SN74LVTH245A芯片<b class='flag-5'>實現(xiàn)</b>長距離<b class='flag-5'>數(shù)據(jù)傳輸</b><b class='flag-5'>系統(tǒng)</b>的設(shè)計