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

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

關(guān)于MCU怎么在擴(kuò)展的SDRAM上運行程序?

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

寫在前面

在使用MCU嵌入式系統(tǒng)設(shè)計中,當(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ā)送正常運行命令

系統(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_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存儲器布局

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

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


SDRAM片選

地址范圍

0

0xA0000000 - 0xA7FFFFFF

1

0xA8000000 - 0xAFFFFFFF

2

0xB0000000 - 0xB7FFFFFF

3

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

#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中運行程序,開發(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í)行的位置獲取指令。

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

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

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

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

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

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • mcu
    mcu
    +關(guān)注

    關(guān)注

    146

    文章

    17173

    瀏覽量

    351627
  • 控制器
    +關(guān)注

    關(guān)注

    112

    文章

    16393

    瀏覽量

    178475
  • SDRAM
    +關(guān)注

    關(guān)注

    7

    文章

    428

    瀏覽量

    55262
收藏 人收藏

    評論

    相關(guān)推薦

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

    電子發(fā)燒友網(wǎng)站提供《EE-239:ADSP-BF533 Blackfin處理器運行閃存程序.pdf》資料免費下載
    發(fā)表于 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物聯(lián)網(wǎng)中的應(yīng)用

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

    TM4C MCU用FreeRTOS開發(fā)通用應(yīng)用程序應(yīng)用說明

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

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

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

    關(guān)于CUBEIDE中使用SDRAM定義變量的問題求解

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

    用Keil上下載按鈕下載執(zhí)行程序和直接斷電執(zhí)行程序,有什么不一樣?

    連接上J-Link或者ST-Link的時候,可以直接在Keil上點擊下面的按鈕下載程序并執(zhí)行程序(當(dāng)然要勾選下載復(fù)位后自動執(zhí)行) 想問的是,這樣下載程序進(jìn)去沒有斷電的軟復(fù)位執(zhí)
    發(fā)表于 05-06 06:43

    STM8S005K6T6C ADC運行程序沒問題,可是轉(zhuǎn)換的結(jié)果全是0,為什么?

    拉輸入,但是檢測總是低電平。換個PD7口就可以用。另外這個STM8S005K6T6C ADC運行程序沒問題,可是轉(zhuǎn)換的結(jié)果全是0.
    發(fā)表于 04-29 08:04

    stm32的運行程序中,初始函數(shù)明明沒有while函數(shù)里面,為什么能反復(fù)運行

    stm32的運行程序中,好多初始函數(shù)明明沒有while函數(shù)里面,但是,他卻能反復(fù)的,不斷地去運行,這是為什么呢? 就像是這個程序,對于設(shè)
    發(fā)表于 04-08 08:15

    STM32H750如何使用IAR調(diào)試運行在外部SDRAM程序?

    (.mac file)腳本,程序下載前,運行腳本初始化外部SDRAM,然后直接下載程序到外部SDRA
    發(fā)表于 04-01 07:40

    STM32HIAR中如何實現(xiàn)從FLASH加載到SRAM中運行程序

    如題,STM32H IAR中如何實現(xiàn)從FLASH加載到SRAM中運行程序 有沒有相關(guān)的例程可供參考
    發(fā)表于 03-28 07:46

    你好 tms570能夠直接運行在片內(nèi) sram嗎?

    你好 tms570能夠直接跑sram嗎? 從flash加載程序1之后,程序1把程序2搬移到sram中,然后
    發(fā)表于 01-19 09:24

    使用ADS并使用ILLD和367DP MCU,賦值運算符沒有按預(yù)期運行的原因?

    我正在使用 ADS 并使用 ILLD 和 367DP MCU。 從字面上看,賦值運算符沒有按預(yù)期運行。 例如,考慮以下代碼(這是一個極其簡化的示例,實際,它涉及將SPI結(jié)果分配給一個變量以通過
    發(fā)表于 01-18 10:43

    使用hyperubs接口的hyperram能否運行程序還是只能作為數(shù)據(jù)存儲來使用?

    使用hyperubs接口的hyperram能否運行程序還是只能作為數(shù)據(jù)存儲來使用,謝謝!
    發(fā)表于 01-18 06:18

    GD32 MCU進(jìn)入低功耗模式導(dǎo)致無法再進(jìn)行程序下載怎么辦?

    很多朋友調(diào)試GD32 MCU的低功耗模式時會遇到一個問題:程序中讓MCU進(jìn)入了Sleep、Deepsleep或者Standby模式,之后MCU
    的頭像 發(fā)表于 01-12 09:41 ?3286次閱讀
    GD32 <b class='flag-5'>MCU</b>進(jìn)入低功耗模式導(dǎo)致無法再進(jìn)<b class='flag-5'>行程序</b>下載怎么辦?

    ADuCM320 flash數(shù)據(jù)區(qū)擦/寫操作時,無法從這塊flash執(zhí)行程序怎么解決?

    UG看到說一塊128K flash擦除或?qū)懖僮鲿r,就無法從這塊flash執(zhí)行程序,截
    發(fā)表于 01-11 06:34
    主站蜘蛛池模板: 老色批影院| 国产一级aa大片毛片| 亚洲三级小视频| 岛国最新资源网站| 五月婷婷之婷婷| 亚洲狠狠狠一区二区三区| 国产操女| 人人添| 狠狠色色综合网站| 五月婷婷六月婷婷| 日本成人一级片| 精品三级内地国产在线观看 | 69久久| 狠狠色丁香六月色| 高清国产在线| 窝窝午夜视频| 国产在线视频www色| 激情综合在线| 美女视频久久| 天堂网www天堂在线资源链接| 在线午夜视频| 999www成人免费视频| 成年黄网站免费大全毛片| 夜夜做日日做夜夜爽| 亚洲在线a| 激情五月激情综合网| 中文字幕在线一区二区三区 | 国模私拍一区二区三区| 又长又大又粗又硬3p免费视 | 国产无圣光高清一区二区| 午夜视频国语| 天天做天天爱天天影视综合| 亚洲影视久久| 国产午夜免费视频片夜色| 中文字幕在线观看一区二区| 在线不卡一区| 潘金莲国产三级视频在线| 欧美成人aaa大片| 免费国产成高清人在线视频| 沟沟人体一区二区| 奇米在线|