在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
电子发烧友
开通电子发烧友VIP会员 尊享10大特权
海量资料免费下载
精品直播免费看
优质内容免费畅学
课程9折专享价
創作中心

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

3天內不再提示

SDRAM初始化分為6個步驟及SDRAM存儲器布局

GReq_mcu168 ? 來源:未知 ? 2019-11-23 11:38 ? 次閱讀

寫在前面


在使用MCU嵌入式系統設計中,當程序或者數據內存占用太大而無法放入片上閃存或SRAM時,開發者通常考慮使用SDRAM。

別問我為什么你的MCU不支持SDRAM

SDRAM是同步動態隨機存取存儲器的縮寫。在微控制器應用中,微控制器通過使用外部存儲控制器(EMC)操作訪問SDRAM ,SDRAM時鐘頻率通常為100MHz或133MHz。

外部存儲控制器通常不支持DDR SDRAM, 數據只是單邊沿采樣,即并行數據總線可以接受一個命令并在每個時鐘周期傳輸一個數據字。

在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需要留心以下細節:

  1. 由于SDRAM初始化函數使用系統堆棧或全局變量,開發者必須確保系統堆棧或全局變量所在的物理內存上電及時鐘使能。

  2. 在程序跳轉到主程序啟動之前,全局變量未清零或初始化,如果在主函數之前執行SDRAM初始化,開發者必須手動初始化變量。

舉個例子,在LPC5460x中,開發者需要在SystemInit函數中初始化SDRAM,該函數(SystemInit)由Reset_Handler調用。在調用系統初始化之前,要通過設置AHBCLKCTRLSET0寄存器將SRAM時鐘使能。


		

Reset_Handler PROC EXPORT Reset_Handler [WEAK] IMPORT SystemInit IMPORT __main ; clock control SRAM1/SRAM2/SRAM3 for stack LDR r0, = 0x40000220 ; AHBCLKCTRLSET0 MOV r1, #0x38 STR r1, [r0] LDR r0, =SystemInit BLX r0 LDR r0, =__main BX r0 ENDP

SDRAM存儲器布局

當使用SDRAM時,外部存儲控制器(EMC)分配SDRAM一定的地址空間。開發者可以使用鏈接描述文件將代碼或數據分配到SDRAM中。值得注意的是,鏈接器腳本編程在不同IDE之間是不同的。

以LPC5460x系列微控制器為例,SDRAM支持4個片選區,每個片選區最大支持256MB空間。


					

SDRAM片選


					

地址范圍


					

0


					

0xA0000000 - 0xA7FFFFFF


					

1


					

0xA8000000 - 0xAFFFFFFF


					

2


					

0xB0000000 - 0xB7FFFFFF


					

3


					

0xB8000000 - 0xBFFFFFFF

當SDRAM的硬件連接使用SDRAM片選0的情況下,在KEIL平臺下,將加載在SPI FLASH的Coremark基準測試程序拷貝到SDRAM中執行需要以下幾步。(coremark基準測試程序包括core_list_join.c,core_matrix.c,core_state.c及core_util.c)。

  1. 定義SDRAM區域,從0xA0000000開始,大小為0x80000。定義SPI FLASH區域,大小為0x80000(SPI FLASH存儲器的起始地址為0x10000000)。

  2. 在C源碼中使用“SDRAM_Data” 和 “SDRAM_Function”屬性,標記放在SDRAM區域中的數據或程序。(SDRAM_Data和SDRAM_Function只是文本名字)。

  3. 也可以將整個目標文件的數據和程序段配置到SDRAM


		

#define m_spifi_start 0x10000000 #define m_spifi_size 0x800000 #define m_sdram_start 0xA0000000 #define m_sdram_size 0x80000 LR_m_text2 m_spifi_start m_spifi_size { ; load to SPIFI LR_m_sdram_text m_sdram_start m_sdram_size { *(SDRAM_Data) *(SDRAM_Function) core_list_join.o core_matrix.o core_state.o core_util.o }

配置MPU

在SDRAM中運行程序,開發者可能需要配置ARM內核內存保護單元(MPU)。

內存保護單元(MPU)是一個可編程單元,用于定義內存訪問權限。當MPU沒有使能時,內存地址空間具有默認的訪問權限。

如ARM Cortex-M4器件通用用戶指南中所述,當程序執行SDRAM中的代碼且SDRAM內存影射地址的默認屬性為禁止執行時, 內核就會產生HARDFAULT異常,且指令訪問沖突標志SCB->CFSR為 1,該異常表示處理器嘗試從不允許執行的位置獲取指令。

因此,當SDRAM被影射到默認不可執行的地址空間時(如在LPC5460x中,SDRAM影射到0xA0000000起始的地址),開發者必須配置并使能MPU才能在SDRAM中執行代碼。如下例中,代碼配置并使能MPU,允許從0xA0000000到0xA0100000的內存區域是可執行的。


		

MPU->RNR = 0; //Region number 0 MPU->RBAR = 0xA0000000; //Region base address /* Full Access | TEX: 000 | S: 0 | C: 0 | B:0 (No cacheable, no shareable)| 1M SIZE | ENABLE */ MPU->RASR = (0 << 28) | (0x3 << 24) | (0x0 << 19) | (0 << 18) | (0 << 17) | (0 << 16) | (0xFF < 8) | (0x13 << 1) | (1 << 0); //Region size and enable MPU->CTRL = MPU_CTRL_ENABLE_Msk | MPU_CTRL_PRIVDEFENA_Msk;

SDRAM性能基準

最后,小編在LPC5460x經過程序運行CoreMark性能基準測試,總結了一點點經驗,分享給大家

  1. SDRAM(16位帶寬)中的代碼執行效率僅為在內部SRAM中執行效率性能40%,大約是內部FLASH中運行代碼性能的50%;

  2. 代碼在SDRAM中運行時,較高的CPU頻率(CPU沒有Cache)不能改善執行效率,這時SDRAM帶寬成為系統性能的瓶頸。

基于這樣的測試結果,建議大家在要求較高性能時,把程序代碼放在內部SRAM執行,而用片外大容量的SDRAM存放海量的數據。


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

    關注

    146

    文章

    17668

    瀏覽量

    357497
  • SDRAM
    +關注

    關注

    7

    文章

    438

    瀏覽量

    55866

原文標題:MCU怎么在擴展的SDRAM上運行程序?

文章出處:【微信號:mcu168,微信公眾號:硬件攻城獅】歡迎添加關注!文章轉載請注明出處。

收藏 1人收藏
  • 一路与你相伴1

評論

相關推薦

SDRAM理論基礎講解

SDRAM的引腳,就必須要看SDRAM的datasheet。 三、學習SDRAM初始化的配置過程對于的初始化,也是需要參考官方文檔的。 對于
發表于 03-26 14:35

嵌入式存儲器的應用:sDRAM硬件連接方案以及軟件接口的實現

分為靜態隨機存儲器(SRAM)、動態隨機存儲器(DRAM)及SDRAM。1SRAM單元通常由4~6
發表于 08-12 00:00

SDRAM它是怎么工作的?

結構體一、SDRAM 同步動態隨機存儲器(也是一芯片)問題:它出什么地方來的呢?為什么會用到它?它怎么工作的?stm32控制芯片內部有一定大小的SRAM和FLASH作為內存和程序儲存空間,但是有時候后可能程序比較大,內存就不夠
發表于 01-20 08:22

嵌入式裸機之匯編初始化SDRAM實現過程

1.SDRAM引入1.1 常見存儲器介紹:DRAM介紹同步動態隨機存取內存(synchronous dynamic random-access memory,簡稱SDRAM),有一
發表于 05-16 15:03

SDRAM存儲器部分電路圖

SDRAM存儲器部分電路
發表于 05-07 18:41 ?21次下載

SDRAM控制的設計

在很多通信芯片及系統的開發中,常常需要用到存儲容量大、讀寫速度快的存儲器。在各種隨機存儲器件中,SDRAM的價格低、體積小、速度快、容量大,是比較理想的器件。但是,與SRAM相比較,
發表于 11-28 19:51 ?5次下載
<b class='flag-5'>SDRAM</b>控制<b class='flag-5'>器</b>的設計

DRAM、SDRAM及DDR SDRAM之間的概念詳解

DRAM (動態隨機訪問存儲器)對設計人員特別具有吸引力,因為它提供了廣泛的性能,用于各種計算機和嵌入式系統的存儲系統設計中。本文概括闡述了DRAM 的概念,及介紹了SDRAM、DDR SD
發表于 06-07 22:10 ?9.3w次閱讀

SDRAM存儲器相關資料下載

SDRAM存儲器相關資料下載
發表于 05-02 11:46 ?49次下載
<b class='flag-5'>SDRAM</b><b class='flag-5'>存儲器</b>相關資料下載

FPGA讀寫SDRAM的實例和SDRAM的相關文章及一些SDRAM控制設計論文

SDRAM的原理和時序,SDRAM控制,動態隨即存儲器SDRAM模塊功能簡介,基于FPGA的SDRA
發表于 12-25 08:00 ?57次下載
FPGA讀寫<b class='flag-5'>SDRAM</b>的實例和<b class='flag-5'>SDRAM</b>的相關文章及一些<b class='flag-5'>SDRAM</b>控制<b class='flag-5'>器</b>設計論文

SDRAM存儲器模塊的簡介

SDRAM與 Flash不同,它不具有掉電保持數據的特性,但其存取速度大大高于 Flash存儲器,且具有讀/寫的屬性,因此 SDRAM在系統中主要用作程序的運行空間,數據及堆棧區。當系統啟動
發表于 12-18 16:13 ?12次下載
<b class='flag-5'>SDRAM</b><b class='flag-5'>存儲器</b>模塊的簡介

EE-286:將SDRAM存儲器連接到SHARC?處理

EE-286:將SDRAM存儲器連接到SHARC?處理
發表于 04-28 09:53 ?4次下載
EE-286:將<b class='flag-5'>SDRAM</b><b class='flag-5'>存儲器</b>連接到SHARC?處理<b class='flag-5'>器</b>

STM32H750_FMC_SDRAM 初始化流程總結

STM32H750_FMC_SDRAM使用STM32CUBEMX 初始化FMC部分,SDRAM 關于延時部分參數模式寄存#define SDRAM
發表于 12-29 18:49 ?2次下載
STM32H750_FMC_<b class='flag-5'>SDRAM</b> <b class='flag-5'>初始化</b>流程總結

STM32H7實現BootLoader內SDRAM初始化注意事項

Function Implementation:在 ArtPi 的環境下,實現一簡單的 BootLoader,該 BootLoader 實現了 QSPI 和 SDRAM 功能的初始化
的頭像 發表于 06-07 15:51 ?4187次閱讀
STM32H7實現BootLoader內<b class='flag-5'>SDRAM</b>的<b class='flag-5'>初始化</b>注意事項

SDRAM工作原理 SDRAM布局布線說明

SDRAM全稱Synchronous Dynamic RAM,同步動態隨機存儲器。首先,它是RAM,即隨機存儲器的一種。
發表于 08-08 15:10 ?2650次閱讀
<b class='flag-5'>SDRAM</b>工作原理 <b class='flag-5'>SDRAM</b><b class='flag-5'>布局</b>布線說明

SDRAM同步動態隨機存儲器的操作說明

SDRAM是做嵌入式系統中,常用是的緩存數據的器件。基本概念如下(注意區分幾個主要常見存儲器之間的差異)。
的頭像 發表于 11-05 17:35 ?785次閱讀
<b class='flag-5'>SDRAM</b>同步動態隨機<b class='flag-5'>存儲器</b>的操作說明
主站蜘蛛池模板: 轻点太大了好深好爽h文 | 久操精品在线观看 | 乱人伦小说短篇 | 久青草免费视频手机在线观看 | 国产成人精品一区二区仙踪林 | 色咯咯| 美女全黄网站免费观看 | 性视频软件 | 亚洲国产精品自在现线让你爽 | 成人高清毛片a | 五月婷婷六月激情 | 嫩草影院久久国产精品 | 69堂在线观看国产成人 | 国产网站在线播放 | 狠狠摸狠狠操 | 色婷婷激婷婷深爱五月老司机 | 色老成人精品视频在线观看 | 天天操天天爱天天干 | 天天拍夜夜添久久精品中文 | 性欧美黑人 | 亚洲视频精品 | 国产专区青青草原亚洲 | 男女艹逼软件 | 狠狠色丁香久久综合五月 | 亚洲成a人不卡在线观看 | 欧美色炮| 色5月婷婷| 天天拍夜夜添久久精品中文 | 4438x成人网最大色成网站 | 色老头综合 | 中文字幕在线播放不卡 | 韩国三级hd中文字幕 | 亚洲欧美精品 | 一卡二卡三卡四卡无卡在线 | 分分操免费视频在线观看 | 国产欧美日韩综合精品无毒 | 欧美日一区二区三区 | 国产免费一级高清淫日本片 | 7777奇米| 在线网址你懂的 | 欧美成人黄色 |

電子發燒友

中國電子工程師最喜歡的網站

  • 2931785位工程師會員交流學習
  • 獲取您個性化的科技前沿技術信息
  • 參加活動獲取豐厚的禮品