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

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

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

3天內不再提示

關于MCU怎么在擴展的SDRAM上運行程序?

黃工的嵌入式技術圈 ? 來源:21ic電子網 ? 作者:21ic電子網 ? 2020-03-01 13:17 ? 次閱讀

寫在前面

在使用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 0MPU->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 enableMPU->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

    文章

    17750

    瀏覽量

    358710
  • 控制器
    +關注

    關注

    114

    文章

    16871

    瀏覽量

    182427
  • SDRAM
    +關注

    關注

    7

    文章

    440

    瀏覽量

    55935
收藏 人收藏

    評論

    相關推薦
    熱點推薦

    MCUFlash

    ? ? MCUFlash是微控制器內部集成的非易失性存儲器,主要用于存儲程序代碼、常量數據及系統配置信息。其核心特性與功能如下: 一、定義與類型? 片Flash采用浮柵晶體管技術
    的頭像 發表于 05-06 14:26 ?82次閱讀

    淺談MCURAM

    MCURAM是微控制單元(MCU)中集成于芯片內部的隨機存取存儲器,主要用于程序運行時的數據存儲與高速讀寫操作。以下是其核心要點: 一、
    的頭像 發表于 04-30 14:47 ?121次閱讀

    DDR3 SDRAM配置教程

    DDR3 SDRAM(Double-Data-Rate ThreeSynchronous Dynamic Random Access Memory)是DDR SDRAM的第三代產品,相較于DDR2,DDR3有更高的運行性能與更低
    的頭像 發表于 04-10 09:42 ?1306次閱讀
    DDR3 <b class='flag-5'>SDRAM</b>配置教程

    如何在 樹莓派 編寫和運行 C 語言程序

    本教程中,我將討論C編程語言是什么,C編程的用途,以及如何在RaspberryPi編寫和運行C程序。本文的目的是為您介紹Raspber
    的頭像 發表于 03-25 09:28 ?307次閱讀
    如何在 樹莓派 <b class='flag-5'>上</b>編寫和<b class='flag-5'>運行</b> C 語言<b class='flag-5'>程序</b>?

    用stsw-link004這個軟件配合仿真器寫程序后,直接運行程序程序運行不正常是什么原因?

    用stsw-link004這個軟件配合仿真器寫程序后,直接運行程序程序運行不正常,必須對電路板進行完全重新電,
    發表于 03-07 07:00

    EE-239:ADSP-BF533 Blackfin處理器運行閃存程序

    電子發燒友網站提供《EE-239:ADSP-BF533 Blackfin處理器運行閃存程序.pdf》資料免費下載
    發表于 01-07 13:58 ?0次下載
    EE-239:<b class='flag-5'>在</b>ADSP-BF533 Blackfin處理器<b class='flag-5'>上</b><b class='flag-5'>運行</b>閃存<b class='flag-5'>程序</b>

    MCU的定義和作用 MCU物聯網中的應用

    (Microcontroller)的簡稱,它是一種專為嵌入式應用設計的計算機芯片。 作用: 數據處理: MCU能夠執行程序指令,處理數據,實現復雜的算法。 控制功能: MCU可以控制各種外部設備,如電機、傳感器等,實現自動化控制
    的頭像 發表于 11-11 14:45 ?3372次閱讀

    DVEVM通過ddd運行Demo

    電子發燒友網站提供《DVEVM通過ddd運行Demo.pdf》資料免費下載
    發表于 10-15 10:05 ?0次下載
    <b class='flag-5'>在</b>DVEVM<b class='flag-5'>上</b>通過ddd<b class='flag-5'>運行</b>Demo

    TM4C MCU用FreeRTOS開發通用應用程序應用說明

    電子發燒友網站提供《TM4C MCU用FreeRTOS開發通用應用程序應用說明.pdf》資料免費下載
    發表于 09-11 14:15 ?0次下載
    <b class='flag-5'>在</b>TM4C <b class='flag-5'>MCU</b><b class='flag-5'>上</b>用FreeRTOS開發通用應用<b class='flag-5'>程序</b>應用說明

    區域架構和 MCU I/O 擴展

    電子發燒友網站提供《區域架構和 MCU I/O 擴展.pdf》資料免費下載
    發表于 09-09 10:51 ?0次下載
    區域架構和 <b class='flag-5'>MCU</b> I/O <b class='flag-5'>擴展</b>

    TM4C MCU使用FreeRTOS開發高級應用

    電子發燒友網站提供《TM4C MCU使用FreeRTOS開發高級應用.pdf》資料免費下載
    發表于 09-06 10:17 ?2次下載
    <b class='flag-5'>在</b>TM4C <b class='flag-5'>MCU</b><b class='flag-5'>上</b>使用FreeRTOS開發高級應用

    RT-Thread Studio每次重開后構建都無法運行程序怎么解決?

    RT-Thread Studio每次重開后構建都 無法運行程序 “make”:Launching failed 只要新建一個項目之后就又可以了 但退出之后又不行了 已經設置了路徑 make是能在任意位置運行的,重啟過RT-Thread Studio也是一樣的
    發表于 07-18 07:33

    關于CUBEIDE中使用SDRAM定義變量的問題求解

    MCU為STM32H743。 因為正在做的項目的數據量比較大,所以要將某些大的數組放到SDRAM中。我ld文件中的段定義如下圖: MEMORY{FLASH (rx): ORIGIN
    發表于 07-05 07:35

    芯海通用 MCU 應用筆記: MDK 開發環境下代碼重定向到 RAM 執行的幾種方法

    。對于多數 MCU 來說 RAM 中執行程序的功耗比 FLASH 中小,對于大部分運行時間執行較小代碼量場景可以降低功耗。 可以操作整個
    發表于 05-16 11:58

    關于ECU 和 MCU ,你了解多少?

    關于MCU和SoC的區別,有一些爭議;同時ECU和MCU的區別,也有一些爭議。如果按照芯片工程師的理解,可以把SoC和MCU都理解為單片機;那虛擬原型技術既可以虛擬化
    的頭像 發表于 05-11 08:10 ?3743次閱讀
    <b class='flag-5'>關于</b>ECU 和 <b class='flag-5'>MCU</b> ,你了解多少?
    主站蜘蛛池模板: 日韩一级片免费在线观看 | 午夜免费观看福利片一区二区三区 | 一级a爰片久久毛片 | 午夜欧美性视频在线播放 | 伊人网综合在线 | 欧美日本一区二区三区道 | 美女网站色免费 | 狠狠躁夜夜躁人人爽天天3 狠狠躁夜夜躁人人爽天天段 | 天天干天天爱天天射 | 99xxxx开心 | 色网站免费 | 深爱五月网| 天天射天天干天天舔 | 羞羞漫画喷水漫画yy漫画 | 亚洲一区二区中文字幕 | 国产成人综合自拍 | 久久综合综合久久 | 狠狠色噜噜狠狠狠狠97不卡 | 亚洲丝袜一区二区 | 国产精品美女免费视频大全 | 寡妇影院首页亚洲图片 | 99青草青草久热精品视频 | 亚洲人成电影在线 | 色综合久久九月婷婷色综合 | 国产热 | 久久久五月天 | 美女扒开内裤无遮挡禁18 | 久久人人精品 | 国产操女| 免费人成激情视频在线观看冫 | 正在播放久久 | 中文字幕网资源站永久资源 | 伊人网视频在线 | 国产精品久久久久久吹潮 | 正在播放淫亚洲 | 99国产成人精品2021 | 国产未成女年一区二区 | 国产色婷婷精品综合在线观看 | 成人夜色视频网站在线观看 | 毛片网站免费在线观看 | 亚洲国产高清精品线久久 |