是否有必要學習使用純Verilog寫一個SDRAM控制器

来源:https://www.cnblogs.com/ninghechuan/archive/2018/04/21/8903938.html
-Advertisement-
Play Games

在做這個SDRAM控制器之前,博主有一個疑問,對於學生來說,是否有必要學慣用純Verilog寫一個SDRAM控制器?因為目前X家和A家都有了DDR IP Core,對於要實現一個應用可以直接調用IP Core,只需要對其介面操作即可。對於開發者來說,與其費時費力用Verilog去寫一個性能差而且老的 ...


  在做這個SDRAM控制器之前,博主有一個疑問,對於學生來說,是否有必要學慣用純Verilog寫一個SDRAM控制器?因為目前X家和A家都有了DDR IP Core,對於要實現一個應用可以直接調用IP Core,只需要對其介面操作即可。對於開發者來說,與其費時費力用Verilog去寫一個性能差而且老的SDRAM控制器,還不如直接調用官方經過打磨的更為先進IP Core。所以博主特地去號稱平均學歷211,平均月薪7、8萬的知(bi)乎提出了這個問題,得到的解答博主總結大致如下。

       對於學生這個身份來說,應該是要以學習為主要目的,雖然說目前企業為了加快項目進度會直接使用IP Core,但是我們以學為本的初衷不應該為了避過難點而直接不去嘗試,就比如我們剛開始學Verilog的時候肯定都會寫過分頻器,那麼為什麼不直接去學更簡單精度更高PLL IP Core呢?從一個新手逐漸成長成一個老手都是由簡單到複雜,由基礎到提升,這是一個必經的過程。這也就是很多高校還是會開設彙編語言編寫單片機的課程,學FPGA全用IP Core和學單片機全用庫函數是一個道理。這是其一。

       第二,寫一個SDRAM控制器還是可以鍛煉一些典型的技能。

  1. 看官方文檔
  2. 根據時序圖設計SDRAM邏輯,使用狀態機
  3. 配合模擬模型寫測試模擬
  4. 調試,提高頻率,讓你的SDRAM跑的更快
  5. 研究時序約束

  這一套做下來,你就可以提高一個層次了,經歷過和沒經歷過是有質的區別。其實博主在提問的時候心中早已有了答案,只是還沒有足夠的信念去完成這個事情,當時看到很多業界前輩都支持去寫的時候,博主心裡也是比較開心的。之前博主已經學一些SDRAM的基礎知識,只是當時水平還不夠,沒有堅持下去,心裡一直不甘。趁著最近兩個月之內沒有什麼事情要忙,所以決定要再次死磕SDRAM。

SDRAM基本概念

  SDRAM(Synchronous Dynamic Random Access Memory),同步動態隨機存儲器。同步是指記憶體工作需要同步時鐘,內部的命令的發送與數據的傳輸都以它為基準。動態是指存儲陣列需要不斷的刷新來保證數據不丟失。隨機是指數據不是線性依次存儲,而是自由指定地址進行數據讀寫。

  我手上的這塊開發板的SDRAM晶元為,海力士的HY57V641620ETP-7,行地址12位,列地址8位,一個存儲單元為16bit,則一個bank的存儲單元為2^12 x 2^8 = 1M,一個bank記憶體為16Mbit。

  SDRAM容量 = 數據位寬x存儲單元數量(bank數x行地址x列地址)

  (一個bank裡面有16Mbit(行地址x列地址x存儲單元位寬))

  The Hynix HY57V641620E(L/S)T(P)  4Bank x 1Mbits x 16 = 64Mbit

  主要特性:

  ·電壓:vdd vddq 3.3v

  ·4096 refresh cycles/64ms

  ·54Pin TSOPII (Thin Small Out-Line Package,薄型小尺寸封裝)

SDRAM內部結構

       SDRAM內部一般有四個bank用來存儲信息,每個bank的行地址和列地址是通用的,bank地址來判斷對哪個bank進行操作。

       每個bank的存儲數據方式就如同一個表格一樣,通過行地址和列地址來確定一個數據,每個數據為16位。我手上的這塊SDRAM的列地址是8位,行地址是12位也就是說一共是2^12 = 4096行,2^8 = 256列。每個bank能存儲1048576個數據,1048576 x 16bit = 1M x 16bit = 16Mbit,那麼這個SDRAM一共可以存儲4 x 16Mbit = 64Mbit。SDRAM的存儲容量也就是這麼計算來的。

引腳說明

對於一些引腳的描述,還是直接看英文的好。

Note:其他的沒啥說的,一般的晶元引腳都這樣,這是要提的是UDQM,LDQM這兩個引腳,數據掩碼,UDQM為高電平,DQ0~DQ15數據匯流排的高位元組即DQ8~DQ15呈現高阻態(全零),LDQM為高電平,DQ0~DQ15數據匯流排的高位元組即DQ0~DQ7呈現高阻態(全零)。韋德是屏蔽輸入輸出信號。

模式寄存器

A4—A6 CAS Latency  列選通潛伏期設置寄存器,這個意思為當我們給讀命令之後,SDRAM等待2/3/reserved個時鐘周期之後才會進行操作。

突髮長度為4              Addr = 12’b0000_0110_0010

突髮長度為full page    Addr = 12’b0000_0110_0111

Burst length(激髮長度)。突髮長度為4指給一次讀或寫命令SDRAM會連續的讀四個數據或連續的寫四個數據,同理 SDRAM支持頁讀寫,當burst length為111是full page一次讀寫命令可以讀/寫一整頁的數據。

我這裡這個設計中設置潛伏期為3,突髮長度為4。

SDRAM操作命令

       SDRAM的操作命令可以從手冊中查到,我用到的就這麼幾個。由片選有效、行有效、列有效、寫使能信號組成。對於這些SDRAM的基本特性都是可以在官方手冊中可以直接看到的。不同公司的SDRAM的型號不同但是其讀寫操作模式都是相同的,所以都是可以相互參考,看文檔還直接看英文文檔好。這篇就先簡單記錄SDRAM的基本概念,下次再記錄工作原理和各個功能模塊的設計。

  目前博主也是剛開始學習SDRAM控制器的設計,剛剛實現了一個簡易的SDRAM控制器,頻率這跑到了50Mhz,通過PC端串口發送數據到FIFO緩衝,然後寫入SDRAM,最後再讀出來,用FIFO緩衝再用串口發送到PC端,後面博主會繼續調試,爭取能掛載攝像頭實時處理顯示。

 

轉載請註明出處:NingHeChuan(寧河川)

個人微信訂閱號:開源FPGA

如果你想及時收到個人撰寫的博文推送,可以掃描左邊二維碼(或者長按識別二維碼)關註個人微信訂閱號

知乎ID:NingHeChuan

微博ID:NingHeChuan

原文地址:http://www.cnblogs.com/ninghechuan/p/8903938.html 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • One day Dima and Alex had an argument about the price and quality of laptops. Dima thinks that the more expensive a laptop is, the better it is. Alex ...
  • 1)eclipse打開幫助 2)Eclipse Marketplace,然後搜索AngularJS Eclipse 安裝後重啟就行了 ...
  • Chat 6 set while 語句 for 語句 continue和break就不介紹了吧 下麵說下else 與 一樣, 和 迴圈後面也可以跟著 語句,不過要和 一起連用。 當迴圈正常結束時,迴圈條件不滿足, 被執行; 當迴圈被 結束時,迴圈條件仍然滿足, 不執行。 如下的例子 python v ...
  • 類實例化可生成對象,實例方法就是對象方法,實例變數就是對象屬性。一個對象的生命周期包括三個階段:創建、使用和銷毀。 創建對象 創建對象包括兩個步驟:聲明和實例化。 聲明 聲明對象與聲明普通變數沒有區別,語法格式如下: 其中type是引用類型,即類、介面和數組。示例代碼如下: 該語句聲明瞭字元串類型對 ...
  • 可變/不可變對象定義 不可變對象 該對象所指向的記憶體中的值不能被改變。當改變某個變數時候,由於其所指的值不能被改變,相當於把原來的值複製一份後再改變,這會開闢一個新的地址,變數再指向這個新的地址。 可變對象 該對象所指向的記憶體中的值可以被改變。變數(準確的說是引用)改變後,實際上是其所指的值直接發生 ...
  • 直接插入排序演算法思想: 排序區間 ; 在排序的過程中,整個排序區間被分為兩個子區間: 有序區 和無序區 ; 共進行n-1趟排序,每趟排序都是把無序區的 插到有序區的合適位置上。 ArrayList實現: java int[] a={ 50, 15, 18, 8, 40, 51, 60, 1, 1, ...
  • 操作系統 : CentOS7.3.1611_x64 Python 版本 : 2.7.5 問題描述 編碼過程中有時候會遇到在多個源文件中存在同一個變數名(比如 : writeBuffer),需要替換為新的變數名(比如 : write_buffer)的問題。 怎麼能方便快捷的解決該問題呢? 解決方案 使 ...
  • 配置指令 管理會話存儲介質 確定如何存儲會話信息 session. save_handler = files(平面文件)mm(共用記憶體)sqlite(SQLite資料庫)user(自定義) 設置會話文件路徑 如果session.save_handler = files,則session.save_p ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...