《電子技術應用》
您所在的位置:首頁 > 模擬設計 > 業界動態 > MCU的嵌入式系統設計,如何運行SDRAM?

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

2020-03-17
來源:與非網
關鍵詞: MCU SDRAM 存儲控制器

  在使用 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_HandlerPROC EXPORTReset_Handler [WEAK] IMPORTSystemInitIMPORT__main ;clock control SRAM1/SRAM2/SRAM3 for stack LDRr0, = 0x40000220 ; AHBCLKCTRLSET0 MOVr1, #0x38 STRr1, [r0] LDRr0, =SystemInit BLXr0 LDRr0, =__main BXr0 ENDP

  SDRAM 存儲器布局

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

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

  SDRAM 片選地址范圍

  00xA0000000 - 0xA7FFFFFF

  10xA8000000 - 0xAFFFFFFF

  20xB0000000 - 0xB7FFFFFF

  30xB8000000 - 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

  # definem_spifi_start 0x10000000 # definem_spifi_size 0x800000 # definem_sdram_start 0xA0000000 # definem_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,該異常表示處理器嘗試從不允許執行的位置獲取指令。

5e702ac714162-thumb.png

  因此,當 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 存放海量的數據。


本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
一区二区三区国产精品| 久久精品国产精品| 欧美精品福利在线| 亚洲日本中文字幕区| 韩国自拍一区| 国产一区二区欧美日韩| 国产欧美日韩在线观看| 国产精品毛片高清在线完整版| 欧美精品在线一区二区三区| 欧美成人黑人xx视频免费观看| 欧美1区2区3区| 欧美成ee人免费视频| 麻豆freexxxx性91精品| 六月婷婷久久| 免费人成网站在线观看欧美高清| 久久一区免费| 欧美刺激午夜性久久久久久久| 欧美r片在线| 欧美大片在线看免费观看| 美女图片一区二区| 免费久久精品视频| 欧美激情一二区| 欧美日韩国产免费观看| 欧美天堂亚洲电影院在线播放| 欧美日本一区| 欧美色图五月天| 国产精品夜夜嗨| 国产在线拍揄自揄视频不卡99| 好看不卡的中文字幕| 在线观看亚洲精品视频| 亚洲欧洲在线视频| 一区二区三区欧美亚洲| 午夜电影亚洲| 久久精品国产免费| 亚洲裸体视频| 亚洲欧美日韩电影| 久久久久久国产精品mv| 欧美成年人网| 国产精品麻豆欧美日韩ww| 国产亚洲综合性久久久影院| 亚洲国产精品99久久久久久久久| 亚洲精品一区二区在线观看| 亚洲一区二区三区精品在线观看| 欧美亚洲一区二区在线| 91久久精品视频| 在线一区日本视频| 欧美一区二区久久久| 美女999久久久精品视频| 欧美日韩成人一区二区三区| 国产精品视频免费一区| 尤物精品在线| 一区二区三区高清在线观看| 久久国产一区| 亚洲小说春色综合另类电影| 久久久91精品国产| 欧美精品激情blacked18| 国产精品一区二区你懂的| 亚洲高清视频在线观看| 亚洲一区影音先锋| 亚洲激精日韩激精欧美精品| 亚洲影视九九影院在线观看| 久久夜色精品国产| 欧美日韩在线另类| 激情91久久| 在线一区二区日韩| 亚洲激情第一区| 午夜在线观看欧美| 欧美激情国产日韩精品一区18| 国产精品老女人精品视频| 亚洲丰满在线| 午夜视频精品| 在线亚洲伦理| 麻豆精品精华液| 国产精品日韩欧美一区| 亚洲高清资源| 欧美亚洲色图校园春色| 亚洲一区二区三区三| 另类专区欧美制服同性| 国产欧美日韩精品在线| 亚洲乱码一区二区| 亚洲国产精品电影在线观看| 香蕉尹人综合在线观看| 欧美美女bb生活片| 激情欧美一区二区| 午夜精品视频在线观看一区二区| 99xxxx成人网| 麻豆精品在线播放| 国产精品亚洲人在线观看| 日韩小视频在线观看| 亚洲欧洲精品一区二区三区波多野1战4 | 正在播放亚洲| 久久综合一区| 国产午夜亚洲精品理论片色戒| 一二三区精品福利视频| 亚洲精品国精品久久99热| 久久中文在线| 好看的av在线不卡观看| 午夜久久tv| 亚洲欧美综合另类中字| 欧美视频1区| 亚洲免费观看| 日韩视频在线免费| 欧美激情国产高清| 亚洲国产色一区| 亚洲黄色尤物视频| 农夫在线精品视频免费观看| 韩国v欧美v日本v亚洲v| 欧美一区二区三区四区在线观看地址 | 欧美大尺度在线| 亚洲电影专区| 最新国产成人在线观看| 裸体素人女欧美日韩| 韩国在线视频一区| 久久精品国产在热久久 | 一二三区精品福利视频| 亚洲天堂网在线观看| 欧美日韩亚洲精品内裤| 亚洲伦理在线免费看| 在线亚洲+欧美+日本专区| 欧美日韩国产区一| 一本色道久久99精品综合| 一区二区三区国产精品| 欧美日韩国产色视频| 91久久综合| 99热这里只有精品8| 欧美精品自拍| 99视频精品全部免费在线| 亚洲午夜在线| 国产精品视频| 午夜视频在线观看一区二区三区| 欧美在线播放| 国产日韩亚洲欧美| 久久er99精品| 欧美mv日韩mv国产网站| 亚洲欧洲日韩在线| 中文在线不卡视频| 国产精品久久久久久久久久免费 | 欧美日韩一区二区精品| 亚洲精品日韩激情在线电影| 亚洲最新合集| 欧美性猛交99久久久久99按摩| 亚洲视频每日更新| 欧美一乱一性一交一视频| 国产午夜精品在线| 亚洲日本在线观看| 欧美日韩亚洲一区二区| 亚洲愉拍自拍另类高清精品| 久久精品视频在线看| 尤物yw午夜国产精品视频明星 | 在线一区二区三区四区| 国产精品一二三四区| 亚洲福利免费| 欧美激情四色| 亚洲小说欧美另类社区| 久久久精品国产一区二区三区| 亚洲福利视频一区二区| 亚洲一区二区三区在线看 | 在线观看视频欧美| 国产精品99久久久久久久久久久久| 国产精品久久久久久久久久久久久久 | 久久国内精品自在自线400部| 欧美大片在线看| 亚洲午夜电影在线观看| 久久久久综合| 99re视频这里只有精品| 久久精品99久久香蕉国产色戒 | 日韩一级大片在线| 欧美一区二视频在线免费观看| 在线电影一区| 亚洲一区欧美| 一区二区三区在线视频免费观看| 日韩亚洲欧美一区| 国产日韩欧美在线播放不卡| 亚洲精品护士| 国产日韩欧美二区| 99re这里只有精品6| 国产亚洲一区二区三区在线观看| 日韩亚洲国产欧美| 国产色产综合产在线视频| 99riav国产精品| 亚洲国产精品一区二区尤物区| 亚洲女优在线| 亚洲高清久久网| 欧美一区二区视频免费观看| 亚洲国产99精品国自产| 欧美一区二区三区免费观看| 亚洲精品中文字| 久久视频免费观看| 国产精品午夜在线| 99国内精品| 国模套图日韩精品一区二区| 亚洲视频一区二区| 尤物九九久久国产精品的特点| 午夜亚洲伦理| 亚洲老司机av| 巨胸喷奶水www久久久免费动漫| 亚洲一区二区欧美日韩| 欧美乱妇高清无乱码| 亚洲夫妻自拍| 国产日韩在线看片|