色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

以SDR SDRAM 為例,DRAM Device 與 Host 端的接口描述

西西 ? 來源:蝸窩科技 ? 作者:codingbelief ? 2020-09-22 15:34 ? 次閱讀

在前面的文章中,介紹了 DRAM Cell 和 Memory Array。 本文則以 SDR SDRAM 為例,描述 DRAM Device 與 Host 端的接口,以及其內部的其他模塊,包括 Control Logic、IO、Row & Column Decoder 等。

1. SDRAM Interface

SDR SDRAM 是 DRAM 的一種,它與 Host 端的硬件接口如下圖所示:

總線上各個信號的描述如下表所示:

Symbol Type Description
CLK Input 從 Host 端輸出的同步時鐘信號
CKE Input 用于指示 CLK 信號是否有效,SDRAM 會根據此信號進入或者退出 Power down、Self-refresh 等模式
CS# Input Chip Select 信號
CAS# Input Column Address Strobe,列地址選通信
RAS# Input Row Address Strobe, 行地址選通信號
WE# Input Write Enable,寫使能信號
DQML Input 當進行寫數據時,如果該 DQML 為高,那么 DQ[7:0] 的數據會被忽略,不寫入到 DRAM
DQMH Input 當進行寫數據時,如果該 DQMH 為高,那么 DQ[15:8] 的數據會被忽略,不寫入到 DRAM
BA[1:0] Input Bank Address,用于選擇操作的 Memory Bank
A[12:0] Input Address 總線,用于傳輸行列地址
DQ[15:0] I/O Data 總線,用于傳輸讀寫的數據內容

1.1 SDRAM Operations

Host 與 SDRAM 之間的交互都是由 Host 以 Command 的形式發起的。一個 Command 由多個信號組合而成,下面表格中描述了主要的 Command。

Command CS# RAS# CAS# WE# DQM BA[1:0] & A[12:0] DQ[15:0]
Active L L H H X Bank & Row X
Read L H L H L/H Bank & Col X
Write L H L L L/H Bank & Col Valid
Precharge L L H L X Code X
Auto-refresh L L L H X X X
Self-refresh L L L H X X X
Load Mode Register L L L L X REG Value X

1.1.1 Active

Active Command 會通過 BA[1:0] 和 A[12:0] 信號,選中指定 Bank 中的一個 Row,并打開該 Row 的 wordline。在進行 Read 或者 Write 前,都需要先執行 Active Command。

1.1.2 Read

Read Command 將通過 A[12:0] 信號,發送需要讀取的 Column 的地址給 SDRAM。然后 SDRAM 再將 Active Command 所選中的 Row 中,將對應 Column 的數據通過 DQ[15:0] 發送給 Host。

Host 端發送 Read Command,到 SDRAM 將數據發送到總線上的需要的時鐘周期個數定義為 CL。

1.1.3 Write

Write Command 將通過 A[12:0] 信號,發送需要寫入的 Column 的地址給 SDRAM,同時通過 DQ[15:0] 將待寫入的數據發送給 SDRAM。然后 SDRAM 將數據寫入到 Actived Row 的指定 Column 中。

SDRAM 接收到最后一個數據到完成數據寫入到 Memory 的時間定義為 tWR (Write Recovery)。

1.1.4 Precharge

在進行下一次的 Read 或者 Write 操作前,必須要先執行 Precharge 操作。(具體的細節可以參考DRAM Storage Cell章節)

Precharge 操作是以 Bank 為單位進行的,可以單獨對某一個 Bank 進行,也可以一次對所有 Bank 進行。如果 A10 為高,那么 SDRAM 進行 All Bank Precharge 操作,如果 A10 為低,那么 SDRAM 根據 BA[1:0] 的值,對指定的 Bank 進行 Precharge 操作。

SDRAM 完成 Precharge 操作需要的時間定義為 tPR。

1.1.5 Auto-Refresh

DRAM 的 Storage Cell 中的電荷會隨著時間慢慢減少,為了保證其存儲的信息不丟失,需要周期性的對其進行刷新操作。

SDRAM 的刷新是按 Row 進行,標準中定義了在一個刷新周期內(常溫下 64ms,高溫下 32ms)需要完成一次所有 Row 的刷新操作。

為了簡化 SDRAM Controller 的設計,SDRAM 標準定義了 Auto-Refresh 機制,該機制要求 SDRAM Controller 在一個刷新周期內,發送 8192 個 Auto-Refresh Command,即 AR, 給 SDRAM。

SDRAM 每收到一個 AR,就進行 n 個 Row 的刷新操作,其中,n = 總的 Row 數量 / 8192 。
此外,SDRAM 內部維護一個刷新計數器,每完成一次刷新操作,就將計數器更新為下一次需要進行刷新操作的 Row。

一般情況下,SDRAM Controller 會周期性的發送 AR,每兩個 AR 直接的時間間隔定義為 tREFI = 64ms / 8192 = 7.8 us。

SDRAM 完成一次刷新操作所需要的時間定義為 tRFC, 這個時間會隨著 SDRAM Row 的數量的增加而變大。

由于 AR 會占用總線,阻塞正常的數據請求,同時 SDRAM 在執行 refresh 操作是很費電,所以在 SDRAM 的標準中,還提供了一些優化的措施,例如 DRAM Controller 可以最多延時 8 個 tREFI 后,再一起把 8 個 AR 同時發出。

更多相關的優化可以參考《大容量 DRAM 的刷新開銷問題及優化技術綜述》文中的描述。

1.1.6 Self-Refresh

Host 還可以讓 SDRAM 進入 Self-Refresh 模式,降低功耗。在該模式下,Host 不能對 SDRAM 進行讀寫操作,SDRAM 內部自行進行刷新操作保證數據的完整。通常在設備進入待機狀態時,Host 會讓 SDRAM 進入 Self-Refresh 模式,以節省功耗。

更多各個 Command 相關的細節,可以參考后續的DRAM Timing章節。

1.2 Address Mapping

SDRAM Controller 的主要功能之一是將 CPU 對指定物理地址的內存訪問操作,轉換為 SDRAM 讀寫時序,完成數據的傳輸。
在實際的產品中,通常需要考慮 CPU 中的物理地址到 SDRAM 的 Bank、Row 和 Column 地址映射。下圖是一個 32 位物理地址映射的一個例子:

2. SDRAM 內部結構

如圖所示,DRAM Device 內部主要有 Control Logic、Memory Array、Decoders、Reflash Counter 等模塊。在后續的小節中,將逐一介紹各個模塊的主要功能。

2.1 Control Logic

Control Logic 的主要功能是解析 SDRAM Controller 發出的 Command,然后根據具體的 Command 做具體內部模塊的控制,例如:選中指定的 Bank、觸發 refresh 等的操作。

Control Logic 包含了 1 個或者多個 Mode Register。該 Register 中包含了時序、數據模式等的配置,更多的細節會在DRAM Timing章節進行描述。

2.2Row & Column Decoder

Row Decoder 的主要功能是將 Active Command 所帶的 Row Address 映射到具體的 wordline,最終打開指定的 Row。同樣 Column Decoder 則是把 Column Address 映射到具體的 csl,最終選中特定的 Column。

2.3 Memory Array

Memory Array 是存儲信息的主要模塊,具體細節可以參考DRAM Memory Orgization章節的描述。

2.4 IO

IO 電路主要是用于處理數據的緩存、輸入和輸出。其中 Data Latch 和 Data Register 用于緩存數據,DQM Mask Logic 和 IO Gating 等則用于輸入輸出的控制。

2.5 Refresh Counter

Refresh Counter 用于記錄下次需要進行 refresh 操作的 Row。在接收到 AR 或者在 Self-Refresh 模式下,完成 一次 refresh 后,Refresh Counter 會進行更新。

3. 不同類型的 SDRAM

目前市面上在使用的 DRAM 主要有 SDR、DDR、LPDDR、GDDR 這幾類,后續小節中,將對各種類型的 DRAM 進行簡單的介紹。

3.1 SDR 和 DDR

SDR(Single Data Rate) SDRAM 是第一個引入 Clock 信號的 DRAM 產品,SDR 在 Clock 的上升沿進行總線信號的處理,一個時鐘周期內可以傳輸一組數據。

DDR(Double Data Rate) SDRAM 是在 SDR 基礎上的一個更新。DDR 內部采用 2n-Prefetch 架構,相對于 SDR,在一個讀寫周期內可以完成 2 倍寬度數據的預取,然后在 Clock 的上升沿和下降沿都進行數據傳輸,最終達到在相同時鐘頻率下 2 倍于 SDR 的數據傳輸速率。(更多 2n-Prefetch 相關的細節可以參考 《Micron Technical Note - General DDR SDRAM Functionality》文中的介紹)

Prefetch 的基本原理如下圖所示。在示例 B 中,內部總線寬度是 A 的兩倍,在一次操作周期內,可以將兩倍于 A 的數據傳輸到 Output Register 中,接著外部 IO 電路再以兩倍于 A 的頻率將數據呈現到總線上,最終實現兩倍 A 的傳輸速率。

DDR 后續還有 DDR2、DDR3、DDR4 的更新,基本上每一代都通過更多的 Prefetch 和更高的時鐘頻率,達到 2 倍于上一代的數據傳輸速率。

DDR SDRAM Standard Bus clock (MHz) Internal rate (MHz) Prefetch (min burst) Transfer Rate (MT/s) Voltage
DDR 100–200 100–200 2n 200–400 2.5/2.6
DDR2 200–533.33 100–266.67 4n 400–1066.67 1.8
DDR3 400–1066.67 100–266.67 8n 800–2133.33 1.5
DDR4 1066.67–2133.33 133.33–266.67 8n 2133.33–4266.67 1.05/1.2

Transfer Rate (MT/s)為每秒發生的 Transfer 的數量,一般為 Bus Clock 的 2 倍 (一個 Clock 周期內,上升沿和下降沿各有一個 Transfer)
Internal rate (MHz)則是內部 Memory Array 讀寫的頻率。由于 SDRAM 采用電容作為存儲介質,由于工藝和物理特性的限制,電容充放電的時間難以進一步的縮短,所以內部 Memory Array 的讀寫頻率也受到了限制,目前最高能到 266.67 MHz,這也是 SDR 到 DDR 采用 Prefetch 架構的主要原因。
Memory Array 讀寫頻率受到限制,那就只能在讀寫寬度上做優化,通過增加單次讀寫周期內操作的數據寬度,結合總線和 IO 頻率的增加來提高整體傳輸速率。

3.2 LPDDRx

LPDDR,即 Low Power DDR SDRAM,主要是用著移動設備上,例如手機、平板等。相對于 DDR,LPDDR 采用了更低的工作電壓、Partial Array Self-Refresh 等機制,降低整體的功耗,以滿足移動設備的低功耗需求。

3.3 GDDRx

GDDR,即 Graphic DDR,主要用在顯卡設備上。相對于 DDR,GDDR 具有更高的性能、更低的功耗、更少的發熱,以滿足顯卡設備的計算需求。

4. 參考資料

Memory Systems - Cache Dram and Disk

大容量 DRAM 的刷新開銷問題及優化技術綜述 [PDF]

Micron Technical Note - General DDR SDRAM Functionality [PDF]

Everything You Need To Know About DDR, DDR2 and DDR3 Memories [WEB]

記憶體10年技術演進史 [WEB]

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • DRAM
    +關注

    關注

    40

    文章

    2337

    瀏覽量

    184294
  • SDRAM
    +關注

    關注

    7

    文章

    437

    瀏覽量

    55564
收藏 人收藏

    評論

    相關推薦

    SDRAM控制器的設計——Sdram_Control.v代碼解析(異步FIFO讀寫模塊、讀寫SDRAM過程)

    前言 SDRAM控制器里面包含5個主要的模塊,分別是PLL模塊,異步FIFO 寫模塊,異步FIFO讀模塊,SDRAM接口控制模塊,SDRAM指令執行模塊。 其中異步FIFO模塊解讀
    的頭像 發表于 03-04 10:49 ?789次閱讀
    <b class='flag-5'>SDRAM</b>控制器的設計——<b class='flag-5'>Sdram</b>_Control.v代碼解析(異步FIFO讀寫模塊、讀寫<b class='flag-5'>SDRAM</b>過程)

    SDRAM控制器設計之command.v代碼解析

    command.v文件對應圖中SDRAM指令執行模塊,它會從SDRAM接口控制模塊接收指令,然后產生控制信號直接輸出到SDRAM器件來完成所接收指令的動作。
    的頭像 發表于 02-25 10:32 ?172次閱讀
    <b class='flag-5'>SDRAM</b>控制器設計之command.v代碼解析

    EE-286:SDRAM存儲器與SHARC處理器的接口

    電子發燒友網站提供《EE-286:SDRAM存儲器與SHARC處理器的接口.pdf》資料免費下載
    發表于 01-06 15:47 ?0次下載
    EE-286:<b class='flag-5'>SDRAM</b>存儲器與SHARC處理器的<b class='flag-5'>接口</b>

    TMS320C6000 EMIF至外部SDRAM接口

    電子發燒友網站提供《TMS320C6000 EMIF至外部SDRAM接口.pdf》資料免費下載
    發表于 10-26 10:06 ?0次下載
    TMS320C6000 EMIF至外部<b class='flag-5'>SDRAM</b><b class='flag-5'>接口</b>

    光纖跳線和光纖尾纖的區別—— 山澤品牌

    在光纖通信和網絡建設中,光纖跳線和光纖尾纖是兩種非常重要的組件。它們在功能和使用場景上有明顯的區別。本文將詳細介紹這兩種光纖組件的區別,并以山澤品牌的產品,幫助你更好地選擇適合自己的光纖組件
    的頭像 發表于 10-21 15:57 ?658次閱讀

    TUSB1002下拉電阻220KΩ和串聯電容330nF,是需要放置在設備device,還是說需要放置在有端子的一

    想請教下,圖中所示下拉電阻220KΩ和串聯電容330nF,是需要放置在設備device,還是說需要放置在有端子的一(不論端子是Host還是Dev
    發表于 10-21 06:18

    光纖跳線常用接口類型—— 山澤品牌

    在現代網絡建設中,光纖跳線是不可或缺的關鍵組件。不同的應用場景需要不同類型的光纖跳線接口。今天,我們就來詳細介紹幾種常見的光纖跳線接口類型,并以山澤品牌的產品,幫助你在選擇時更加得
    的頭像 發表于 10-18 15:58 ?553次閱讀

    測試用怎么寫

    測試方法,旨在驗證整個應用程序從前端到后端的流程是否能夠按照預期工作。它涉及多個系統組件和接口的交互,確保業務流程的完整性和正確性。 二、編寫測試用的步驟 需求分析 理解業務流
    的頭像 發表于 09-20 10:29 ?694次閱讀

    SDRAM的特點與應用

    同步動態隨機存儲器(Synchronous Dynamic Random Access Memory,簡稱SDRAM)是一種基于同步時鐘的DRAM
    的頭像 發表于 07-29 16:56 ?2953次閱讀

    同步DRAM(SDRAM)介紹

    DRAM從20世紀70年代初到90年代初生產,接口都是異步的,其中輸入控制信號直接影響內部功能。
    的頭像 發表于 07-29 09:55 ?1023次閱讀
    同步<b class='flag-5'>DRAM</b>(<b class='flag-5'>SDRAM</b>)介紹

    SDRAM中的active命令介紹

    在向SDRAM 中的任何行發出 READ或 WRITE 命令之前,必須先打開該行。這是通過 ACTIVE 命令完成的。ACTIVE 命令的目的是打開或者說激活(active)bank中的一行并將數據從 DRAM 移動到bank的靈敏放大器。下圖說明了 ACTIVE 命令的
    的頭像 發表于 07-29 09:53 ?608次閱讀
    <b class='flag-5'>SDRAM</b>中的active命令介紹

    ESP32S3使用例程usb_host_lib枚舉device失敗的原因?

    在網店購買了樂鑫那款帶micro usb的esp32s3核心板,使用例程usb_host_lib配置核心板host,使用OTG轉接頭插入U盤,例程可以產生事務回調,并能夠打印出設備的PID/VID
    發表于 06-07 06:53

    請問usb host如何獲得USB設備的描述字符串?

    描述符字符串? 比如我的USB設備: ---------------------- Device Descriptor ---------------------- bLength : 0x12
    發表于 06-06 06:51

    用STM32_USB-Host-Device_Lib USB_Host_ExamplesHID例程,主循環加入延時后按鍵盤不能讀到字符是為什么?

    參考的UM1021手冊,用的STM32_USB-Host-Device_Lib USB_Host_ExamplesHID例程。 插鍵盤使用,USBH_Process() 循環間隔小于3ms,按鍵
    發表于 04-29 07:40

    需要用f4xx做usb vcp host,請問有沒有辦法讓host不輪詢讀呢?

    device發的數據,host不會主動收, 需要host定時調用receive的函數才能收到,請問有沒有辦法讓
    發表于 03-26 08:25
    主站蜘蛛池模板: 国产欧美一区二区精品性色tv | 哺乳期妇女挤奶水36d | 久久久无码精品一区二区三区 | CHRISTMAS农村夫妻HO | 久热这里在线精品 | 久久99精品视频 | 东北女人一级毛片 | 国产AV午夜精品一区二区入口 | 国精产品999一区二区三区有限 | 年轻老师毛茸茸自由性 | 日本50人群体交乱 | 嗯啊快拔出来我是你老师视频 | 4虎最新网址 | 我要色导航 | 97在线精品视频 | 亚洲在线成色综合网站 | 亚洲精品天堂无码中文字幕影院 | 97国产蝌蚪视频在线观看 | 国产成人高清精品免费观看 | 无码任你躁久久久久久老妇双奶 | 末成年美女黄网站色大片连接 | 97人人超碰国产精品最新蜜芽 | 伊人影院亚洲 | 99视频精品全部免费 在线 | 亚洲免费三级电影 | 色悠悠电影网 | 啊灬啊别停灬用力啊在线观看视频 | 亚洲国产欧美国产综合在线 | 手机在线播放成人亚洲影院电影 | 久久国产露脸老熟女熟69 | 欧美精品中文字幕亚洲专区 | 好紧好湿太硬了我太爽了小说 | 高H高肉强J短篇校园 | 999久久免费高清热精品 | 无套内谢大学生A片 | 教室里的激情电影 | 国产色婷亚洲99精品AV在 | 伦理电影v男人天堂 | 伊人不卡久久大香线蕉综合影院 | 97碰成视频免费 | 男女午夜性爽快免费视频不卡 |