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

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

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

3天內不再提示

為什么MCU不支持SDRAM

MCU開發加油站 ? 2019-08-29 10:33 ? 次閱讀

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

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

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

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

在SDRAM中執行程序是使用SDRAM的一種典型用法, 小編這里就介紹一下SDRAM中執行程序的方法和SDRAM執行程序的性能基準。

SDRAM初始化 SDRAM必須在使用前進行配置,SDRAM初始化分為6個步驟。

配置EMC寄存器的SDRAM時鐘頻率、字節順序和時序參數
SDRAM的時序比較復雜,用戶需要通過查閱相關SDRAM芯片的手冊獲得時序參數(如刷新周期、預充電命令周期、自刷新退出時間、寫恢復時間等等)。

發送NOP命令

發送預充電命令

發送兩次自動刷新命令

設置SDRAM模式

發送正常運行命令

系統啟動時,SDRAM尚未初始化。理論上,程序在系統啟動后的任何時刻都可以進行SDRAM初始化。然而,由于SDRAM初始化過程比較復雜,使用的系統資源較多,SDRAM初始化必須在所需的系統資源初始化完成后再進行。

具體上講,開發者在芯片剛剛啟動時(如Reset_Handler中)初始化SDRAM需要留心以下細節:

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

在程序跳轉到主程序啟動之前,全局變量未清零或初始化,如果在主函數之前執行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)。

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

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

也可以將整個目標文件的數據和程序段配置到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性能基準測試,總結了一點點經驗,分享給大家

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

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

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

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

    關注

    146

    文章

    17172

    瀏覽量

    351571
  • SDRAM
    +關注

    關注

    7

    文章

    427

    瀏覽量

    55260

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

文章出處:【微信號:mcugeek,微信公眾號:MCU開發加油站】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    MCU不支持任何LCD顯示嗎?

    我看到很多MCU不支持LCD,以STM32 F4系列為例,該系列很多MCU的 display controller 項都表明“-”,如下圖。那么請問這樣的MCU就完全
    發表于 09-25 11:41

    不支持的BIOS?

    PCIe NVMe(M鍵),它支持上面的UEFI啟動和英特爾RST15.5 ..但是當我安裝optane時,它在intel optane app ver 16.x上說“不支持的BIOS或BIOS設置
    發表于 10-25 14:58

    MCU的嵌入式系統設計,如何運行SDRAM

    時,開發者通常考慮使用 SDRAM。別問我為什么你的 MCU 不支持 SDRAMSDRAM 是同步動態隨機存取存儲器的縮寫。在微控制器應
    發表于 11-04 08:03

    為什么你的MCU不支持SDRAM

    在使用MCU的嵌入式系統設計中,當程序或者數據內存占用太大而無法放入片上閃存或SRAM時,開發者通常考慮使用SDRAM。別問我為什么你的MCU不支持SDRAMSDRAM是...
    發表于 12-16 06:28

    CH32V103不支持開源平臺嗎?

    如題。CH32V103 不支持 J-Link?不支持 Linux 和 macOS 環境?不支持公版 Eclipse、OpenOCD 和 GDB?
    發表于 06-07 11:07

    不支持器件的問題

    我裝了Quartus11.0,裝了器件庫,然后破解了Quartus。可是編譯工程,提示破解文件不支持器件。這應該如何解決?謝謝!
    發表于 03-19 14:26

    蘋果iPad不支持繁體中文

    蘋果iPad不支持繁體中文     北京時間1月29日消息,美國蘋果計算機推出的iPad不支持繁體中文,蘋果臺灣官方表示:要等
    發表于 01-30 09:50 ?1096次閱讀

    小米手表為什么到現在還不支持iOS系統

    小米手表雙11就開售了,不過50天都過去了,卻依然不支持iOS系統,這究竟是什么原因呢?
    發表于 01-02 14:17 ?5542次閱讀

    MCU的嵌入式系統設計如何運行SDRAM

    在使用 MCU 的嵌入式系統設計中,當程序或者數據內存占用太大而無法放入片上閃存或 SRAM 時,開發者通常考慮使用 SDRAM。別問我為什么你的 MCU 不支持
    發表于 12-23 12:18 ?10次下載

    openharmony不支持安卓嗎

    前面議論紛紛的鴻蒙是安卓套殼時代話題結束了,現在,openharmony 支不支持安卓系統的話題又出現了?那么,openharmony 到底支不支持安卓系統呢?
    的頭像 發表于 06-23 09:43 ?2099次閱讀

    華為p50為什么不支持5g

    華為p50為什么不支持5g?這是近日廣大網友用戶吐槽的一個問題,華為已經于近日正式發布了華為p50系列,并將全面支持鴻蒙2.0系統,但是為什么卻不支持5G呢?
    的頭像 發表于 08-01 09:12 ?6.9w次閱讀

    MCU如何在擴展的SDRAM上運行程序?

    在使用MCU的嵌入式系統設計中,當程序或者數據內存占用太大而無法放入片上閃存或SRAM時,開發者通常考慮使用SDRAM。別問我為什么你的MCU不支持
    發表于 10-26 19:20 ?12次下載
    <b class='flag-5'>MCU</b>如何在擴展的<b class='flag-5'>SDRAM</b>上運行程序?

    MCU的嵌入式系統設計,運行SDRAM(運行效率比較)

    時,開發者通常考慮使用 SDRAM。別問我為什么你的 MCU 不支持 SDRAMSDRAM 是同步動態隨機存取存儲器的縮寫。在微控制器應
    發表于 10-29 11:36 ?0次下載
    <b class='flag-5'>MCU</b>的嵌入式系統設計,運行<b class='flag-5'>SDRAM</b>(運行效率比較)

    Questa Sim不支持-novopt問題

    在仿真中為防止信號被優化,會在modelsim仿真的do文件中使用vsim -novopt項,但是Questa Sim已經不支持,并會提示以下信息。所以要觀察信號第一步先要解決該問題。
    的頭像 發表于 12-23 10:34 ?5371次閱讀
    Questa Sim<b class='flag-5'>不支持</b>-novopt問題

    為什么RS485不支持任意拓撲

    RS485不支持任意拓撲,因為任意拓撲在分支處會產生大量的駐波和反射。這是由于阻抗不連續所造成的。
    的頭像 發表于 10-27 11:47 ?929次閱讀
    為什么RS485<b class='flag-5'>不支持</b>任意拓撲
    主站蜘蛛池模板: 女子初尝黑人巨嗷嗷叫| 国产精品亚洲视频在线观看| 啊…嗯啊好深男男高h文总受| 国产在线观看免费观看不卡| 日本欧美高清一区二区视频| jizz老太婆| 暖暖视频 免费 高清 日本8| 最新男同鸭子ktv| 久久亚洲人成国产精品| 月夜直播视频免费观看| 久久视频精品38在线播放| 伊人久久精品AV一区二区| 精品久久久久久综合网| 亚洲三级黄色片| 久久精品免费观看久久| 曰批视频免费40分钟不要钱| 久久a级片| 在线观看日本免费| 蜜桃日本免费观看MV| JK白丝校花爽到娇喘视频| 男人的天堂黄色| 扒开校花粉嫩小泬喷潮漫画| 日本乱子人伦在线视频| 国产VA精品午夜福利视频| 亚洲 欧美 国产 综合不卡 | 亚洲国产cao| 精品亚洲视频在线观看| 在教室伦流澡到高潮HNP视频| 麻豆久久婷婷五月国产| WWWXXXX兽交| 射死你天天日| 鸡鸡插屁股| 99re久久热在线视频| 日韩中文亚洲欧美视频二| 国产无遮挡无码视频在线观看不卡 | 久九九精品免费视频| 2020国产成人免费视频| 欧美激情视频一区| 国产色精品久久人妻无码| 坠落的丝袜美人妻| 熟女啪啪白浆嗷嗷叫|