《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 模擬設(shè)計(jì) > 業(yè)界動態(tài) > MCU的嵌入式系統(tǒng)設(shè)計(jì),如何運(yùn)行SDRAM?

MCU的嵌入式系統(tǒng)設(shè)計(jì),如何運(yùn)行SDRAM?

2020-03-17
來源:與非網(wǎng)
關(guān)鍵詞: MCU SDRAM 存儲控制器

  在使用 MCU 的嵌入式系統(tǒng)設(shè)計(jì)中,當(dāng)程序或者數(shù)據(jù)內(nèi)存占用太大而無法放入片上閃存或 SRAM 時,開發(fā)者通常考慮使用 SDRAM

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

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

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

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

  SDRAM 初始化

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

  配置 EMC 寄存器的 SDRAM 時鐘頻率、字節(jié)順序和時序參數(shù)。

  SDRAM 的時序比較復(fù)雜,用戶需要通過查閱相關(guān) SDRAM 芯片的手冊獲得時序參數(shù)(如刷新周期、預(yù)充電命令周期、自刷新退出時間、寫恢復(fù)時間等等)。

  發(fā)送 NOP 命令

  發(fā)送預(yù)充電命令

  發(fā)送兩次自動刷新命令

  設(shè)置 SDRAM 模式

  發(fā)送正常運(yùn)行命令

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

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

  由于 SDRAM 初始化函數(shù)使用系統(tǒng)堆棧或全局變量,開發(fā)者必須確保系統(tǒng)堆棧或全局變量所在的物理內(nèi)存上電及時鐘使能。

  在程序跳轉(zhuǎn)到主程序啟動之前,全局變量未清零或初始化,如果在主函數(shù)之前執(zhí)行 SDRAM 初始化,開發(fā)者必須手動初始化變量。

  舉個例子,在 LPC5460x 中,開發(fā)者需要在 SystemInit 函數(shù)中初始化 SDRAM,該函數(shù)(SystemInit)由 Reset_Handler 調(diào)用。在調(diào)用系統(tǒng)初始化之前,要通過設(shè)置 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 存儲器布局

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

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

  SDRAM 片選地址范圍

  00xA0000000 - 0xA7FFFFFF

  10xA8000000 - 0xAFFFFFFF

  20xB0000000 - 0xB7FFFFFF

  30xB8000000 - 0xBFFFFFFF

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

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

  在 C 源碼中使用“SDRAM_Data” 和 “SDRAM_FuncTIon”屬性,標(biāo)記放在 SDRAM 區(qū)域中的數(shù)據(jù)或程序。(SDRAM_Data 和 SDRAM_FuncTIon 只是文本名字)。

  也可以將整個目標(biāo)文件的數(shù)據(jù)和程序段配置到 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 中運(yùn)行程序,開發(fā)者可能需要配置 ARM 內(nèi)核內(nèi)存保護(hù)單元(MPU)。

  內(nèi)存保護(hù)單元(MPU)是一個可編程單元,用于定義內(nèi)存訪問權(quán)限。當(dāng) MPU 沒有使能時,內(nèi)存地址空間具有默認(rèn)的訪問權(quán)限。

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

5e702ac714162-thumb.png

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

  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 性能基準(zhǔn)

  最后,小編在 LPC5460x 經(jīng)過程序運(yùn)行 CoreMark 性能基準(zhǔn)測試,總結(jié)了一點(diǎn)點(diǎn)經(jīng)驗(yàn),分享給大家

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

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

  基于這樣的測試結(jié)果,建議大家在要求較高性能時,把程序代碼放在內(nèi)部 SRAM 執(zhí)行,而用片外大容量的 SDRAM 存放海量的數(shù)據(jù)。


本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉(zhuǎn)載內(nèi)容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點(diǎn)。轉(zhuǎn)載的所有的文章、圖片、音/視頻文件等資料的版權(quán)歸版權(quán)所有權(quán)人所有。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無法一一聯(lián)系確認(rèn)版權(quán)者。如涉及作品內(nèi)容、版權(quán)和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當(dāng)措施,避免給雙方造成不必要的經(jīng)濟(jì)損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。
主站蜘蛛池模板: 中文字幕日本在线 | 亚洲h片 | 午夜动态 | 欧美日韩一区二区在线视频播放 | 成人免费视频观看 | 欧美日韩国产另类在线观看 | 狠狠色噜噜狠狠狠狠2018 | 色天使色婷婷丁香久久综合 | 夜夜夜夜爽 | 成人午夜18免费看 | 91免费视| 欧美成人免费看片一区 | 免费高清在线影片一区 | 免费视频成人国产精品网站 | 福利在线免费视频 | 极品蜜桃臀美女啪啪 | 欧美亚洲免费久久久 | 亚洲小视频在线播放 | www插插插 | 亚洲国产精品热久久2022 | 亚洲欧美日韩精品香蕉 | 天天操天天操天天操香蕉 | 看免费毛片 | 欧美极度极品另类 | 免费鲁丝片一级在线观看 | 在线好吊色视频98gao | 国产精品福利无圣光一区二区 | 嘿嘿嘿视频免费网站在线观看 | 日韩精品免费看 | 在线网站黄色 | 亚洲青青青网伊人精品 | 污视频网址 | 国产91精品高跟丝袜在线 | 国产人成亚洲第一网站在线播放 | 国产精品国产三级在线专区 | 亚洲午夜在线视频 | 波多野结衣免费视频观看 | 中国国产一级毛片视频 | 日韩欧美亚洲另类 | 一本大道香蕉大在线最新 | 男女午夜视频 |