日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

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

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

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

關(guān)于MCU怎么在擴展的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)隨機存取存儲器的縮寫。在微控制器應(yīng)用中,微控制器通過使用外部存儲控制器(EMC)操作訪問SDRAM ,SDRAM時鐘頻率通常為100MHz或133MHz。

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

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

SDRAM初始化

SDRAM必須在使用前進行配置,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)啟動后的任何時刻都可以進行SDRAM初始化。然而,由于SDRAM初始化過程比較復(fù)雜,使用的系統(tǒng)資源較多,SDRAM初始化必須在所需的系統(tǒng)資源初始化完成后再進行。

具體上講,開發(fā)者在芯片剛剛啟動時(如Reset_Handler中)初始化SDRAM需要留心以下細節(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基準測試程序拷貝到SDRAM中執(zhí)行需要以下幾步。(coremark基準測試程序包括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”屬性,標記放在SDRAM區(qū)域中的數(shù)據(jù)或程序。(SDRAM_Data和SDRAM_Function只是文本名字)。

也可以將整個目標文件的數(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)存保護單元(MPU)。

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

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

因此,當(dāng)SDRAM被影射到默認不可執(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性能基準

最后,小編在LPC5460x經(jīng)過程序運行CoreMark性能基準測試,總結(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)注

    147

    文章

    19160

    瀏覽量

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

    關(guān)注

    114

    文章

    17886

    瀏覽量

    195290
  • SDRAM
    +關(guān)注

    關(guān)注

    7

    文章

    459

    瀏覽量

    57862
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    STM32N6 PSRAM 運行代碼的調(diào)試

    開發(fā)其產(chǎn)品過程中,使用了 STM32N657X0H3Q。客戶的代碼很大,不能放在SRAM 運行,想放在 PSRAM 上去運行,并咨詢?nèi)绾卧?STM32CubeIDE 上進行調(diào)試。2.2. 重現(xiàn)問題
    發(fā)表于 04-15 16:02 ?0次下載

    RT1052 更換 SDRAM 后,無法正常工作,怎么解決?

    我的 RT1052 板使用 IS42S16160 32MB SDRAM,運行完美。但是,將其更換為IS42S16400 8MB SDRAM 后,它無法正常工作。需要更改哪些配置?
    發(fā)表于 04-02 06:11

    單片機里的程序運行方式

    我們想要理解單片機是如何運行程序的,我們首先需要了解單片機的組成,我們這里以80C51單片機為例來理解程序單片機中是如何運行的。 單片機的組成8051單片機的內(nèi)部硬件結(jié)構(gòu)包括: 中
    發(fā)表于 01-16 06:57

    如何評估SDRAM的有效帶寬

    進行電子系統(tǒng)設(shè)計時,我們經(jīng)常會用到SDRAM(SDR SDRAM或者DDRX SDRAM)作為緩沖單元,但是如何評估SDRAM的有效帶寬呢
    的頭像 發(fā)表于 01-12 09:17 ?571次閱讀
    如何評估<b class='flag-5'>SDRAM</b>的有效帶寬

    office 版本不同,到處可執(zhí)行程序出錯

    本帖最后由 opticalchang 于 2025-12-29 12:41 編輯 編寫程序所用的office 是2016版, 可執(zhí)行程序安裝了office 2007版本的電腦
    發(fā)表于 12-29 10:32

    如何給Gokit3燒錄程序(MCU+FlyMcu版)

    本文中,我們將詳細講解如何為機智云的Gokit3MCU模式進行程序燒錄,特別是針對FlyMcu版本的應(yīng)用。本次燒錄采用了串口方式,這是給MCU燒錄
    的頭像 發(fā)表于 12-17 18:46 ?609次閱讀
    如何給Gokit3燒錄<b class='flag-5'>程序</b>(<b class='flag-5'>MCU</b>+FlyMcu版)

    極海APM32系列MCU中如何把代碼重定位到SDRAM運行

    在有些情況下,我們想要把代碼放到SDRAM運行。下面介紹APM32的MCU中,如何把代碼重定位到SDRAM
    的頭像 發(fā)表于 11-04 09:14 ?5434次閱讀
    <b class='flag-5'>在</b>極海APM32系列<b class='flag-5'>MCU</b>中如何把代碼重定位到<b class='flag-5'>SDRAM</b><b class='flag-5'>運行</b>

    MG51FB9AE MCU中,如何使用LDROM中的IAP加載程序MCUAPROM中上傳程序?

    MG51FB9AE MCU中,如何使用LDROM中的IAP加載程序MCUAPROM中上傳程序
    發(fā)表于 08-22 06:29

    MCU反復(fù)啟動運行緩慢怎么解決?

    我們的 XMC4500 遇到了一個奇怪的問題。某種情況下,我發(fā)現(xiàn) MCU 似乎突然運行得更慢了。我觀察到以下情況: 1) CAN 消息發(fā)送速度大約慢 11.7 倍。 2) 我們的閃爍 LED 頻率
    發(fā)表于 07-15 06:21

    超長行程,精準輸出——飛創(chuàng)長行程直線模組的實力彰顯

    行程直線模組是工業(yè)自動化的重要組件,其最突出的特點是行程范圍大,標準產(chǎn)品行程可達數(shù)米,定制后甚至能達到數(shù)十米,同時還具備高精度定位、高負載承載、高運行速度等優(yōu)勢。
    的頭像 發(fā)表于 07-11 11:45 ?725次閱讀
    超長<b class='flag-5'>行程</b>,精準輸出——飛創(chuàng)長<b class='flag-5'>行程</b>直線模組的實力彰顯

    移植touchgfx之后stm32不運行程序怎么解決?

    MCU:STM32U585CIU6 cubemx:6.14 touchgfx:25 我cubemx配置生成touchgfx的初始化,時基是TIM7,沒有用RTOS,生成之后再用designer隨便
    發(fā)表于 06-06 07:43

    hid usb讀取不到擴展按鍵的問題

    到)以及擴展的兩個按鍵(這兩按鍵的按鍵碼分別為01和02),這兩個擴展按鍵程序接受不到任何信息,通過鍵盤hook和raw input也只能接受到遙控器的一頁、下一頁按鍵的信息,接收不
    發(fā)表于 05-20 20:22

    為什么無法運行程序“make”(目錄“C:\\?

    FX2LP Build,得到了 14:26:46 **** 為項目 Fx2Test 構(gòu)建配置調(diào)試 **** 全部制作 無法運行程序“make”(目錄“C
    發(fā)表于 05-15 08:26

    同樣的代碼官方開發(fā)板運行正常,自己板子就跑不起來,怎么辦?

    同樣的代碼Nordic官方開發(fā)板可以運行正常,但在自己板子就跑不起來,如果你碰到了上述情況,建議按照如下步驟進行自檢: 首先確認用戶板元器件焊接良好,功能正常。如果你的板子有LE
    的頭像 發(fā)表于 05-12 15:26 ?928次閱讀
    同樣的代碼<b class='flag-5'>在</b>官方開發(fā)板<b class='flag-5'>上</b><b class='flag-5'>運行</b>正常,<b class='flag-5'>在</b>自己板子<b class='flag-5'>上</b>就跑不起來,怎么辦?

    MCUFlash

    ? ? MCUFlash是微控制器內(nèi)部集成的非易失性存儲器,主要用于存儲程序代碼、常量數(shù)據(jù)及系統(tǒng)配置信息。其核心特性與功能如下: 一、定義與類型? 片Flash采用浮柵晶體管技術(shù)
    的頭像 發(fā)表于 05-06 14:26 ?1594次閱讀
    绥江县| 奈曼旗| 德安县| 兴隆县| 达日县| 阿巴嘎旗| 涟水县| 双流县| 鄂温| 曲靖市| 定安县| 福鼎市| 辽宁省| 涿州市| 仪陇县| 武胜县| 衡阳市| 田林县| 鸡泽县| 德惠市| 上栗县| 浠水县| 邛崃市| 山阳县| 杭锦旗| 福建省| 偃师市| 镇巴县| 汶川县| 汕尾市| 余江县| 洪洞县| 财经| 彭阳县| 扶风县| 潍坊市| 仁布县| 扶绥县| 江华| 桦南县| 鹤山市|