MCU如何在擴展的SDRAM上運行程序?
來源:21ic電子網 日期:2022-03-03 14:36:36
在使用
MCU的嵌入式系統設計中,當程序或者數據內存占用太大而無法放入片上閃存或
SRAM時,開發者通常考慮使用SDRAM。
SDRAM是同步動態隨機存取存儲器的縮寫。在微控制器應用中,微控制器通過使用外部存儲控制器(EMC)操作訪問SDRAM ,SDRAM時鐘頻率通常為100MHz或133MHz。
外部存儲控制器通常不支持DDR SDRAM, 數據只是單邊沿采樣,即并行數據總線可以接受一個命令并在每個時鐘周期傳輸一個數據字。
在SDRAM中執行程序是使用SDRAM的一種典型用法, 這里就介紹一下SDRAM中執行程序的方法和SDRAM執行程序的性能基準。
SDRAM必須在使用前進行配置,SDRAM初始化分為6個步驟。
1、配置EMC寄存器的SDRAM時鐘頻率、字節順序和時序參數。
SDRAM的時序比較復雜,用戶需要通過查閱相關SDRAM芯片的手冊獲得時序參數(如刷新周期、預充電命令周期、自刷新退出時間、寫恢復時間等等)。
2、發送NOP命令
3、發送預充電命令
4、發送兩次自動刷新命令
5、設置SDRAM模式
6、發送正常運行命令
系統啟動時,SDRAM尚未初始化。理論上,程序在系統啟動后的任何時刻都可以進行SDRAM初始化。然而,由于SDRAM初始化過程比較復雜,使用的系統資源較多,SDRAM初始化必須在所需的系統資源初始化完成后再進行。
具體上講,開發者在芯片剛剛啟動時(如Reset_Handler中)初始化SDRAM需要留心以下細節:
由于SDRAM初始化函數使用系統堆棧或全局變量,開發者必須確保系統堆棧或全局變量所在的物理內存上電及時鐘使能。
在程序跳轉到主程序啟動之前,全局變量未清零或初始化,如果在主函數之前執行SDRAM初始化,開發者必須手動初始化變量。
本文關鍵詞:MCU,SRAM,SDRAM
相關文章:靈動微電子MM32F0130單片機智能插座的參考方案
宇芯有限公司自成立以來,我們專注于代理國內外各大知名品牌的半導體元器件,代理品牌有NETSOL、JSC、everspin代理、來楊Lyontek、ISSI、CYPRESS,VTI等多個品牌總代理資質,主要產品線為sram、mram、psram等其他存儲器芯片,致力于為客戶提供具有競爭優勢的產品,是一家專業提供存儲方案解決商。