www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁(yè) > 嵌入式 > 嵌入式微處理器
[導(dǎo)讀]在使用MCU的嵌入式系統(tǒng)設(shè)計(jì)中,當(dāng)程序或者數(shù)據(jù)內(nèi)存占用太大而無(wú)法放入片上閃存或SRAM時(shí),開(kāi)發(fā)者通??紤]使用SDRAM。別問(wèn)我為什么你的MCU不支持SDRAM。SDRAM是同步動(dòng)態(tài)隨機(jī)存取存儲(chǔ)器的縮寫。在微控制器應(yīng)用中,微控制器通過(guò)使用外部存儲(chǔ)控制器(EMC)操作訪問(wèn)SDRAM,...


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

別問(wèn)我為什么你的MCU不支持SDRAM。
SDRAM是同步動(dòng)態(tài)隨機(jī)存取存儲(chǔ)器的縮寫。在微控制器應(yīng)用中,微控制器通過(guò)使用外部存儲(chǔ)控制器(EMC)操作訪問(wèn)SDRAM ,SDRAM時(shí)鐘頻率通常為100MHz或133MHz。
外部存儲(chǔ)控制器通常不支持DDR SDRAM, 數(shù)據(jù)只是單邊沿采樣,即并行數(shù)據(jù)總線可以接受一個(gè)命令并在每個(gè)時(shí)鐘周期傳輸一個(gè)數(shù)據(jù)字。
在SDRAM中執(zhí)行程序是使用SDRAM的一種典型用法, 小編這里就介紹一下SDRAM中執(zhí)行程序的方法和SDRAM執(zhí)行程序的性能基準(zhǔn)。


SDRAM初始化



SDRAM必須在使用前進(jìn)行配置,SDRAM初始化分為6個(gè)步驟。
  1. 配置EMC寄存器的SDRAM時(shí)鐘頻率、字節(jié)順序和時(shí)序參數(shù)。
    SDRAM的時(shí)序比較復(fù)雜,用戶需要通過(guò)查閱相關(guān)SDRAM芯片的手冊(cè)獲得時(shí)序參數(shù)(如刷新周期、預(yù)充電命令周期、自刷新退出時(shí)間、寫恢復(fù)時(shí)間等等)。
  2. 發(fā)送NOP命令
  3. 發(fā)送預(yù)充電命令
  4. 發(fā)送兩次自動(dòng)刷新命令
  5. 設(shè)置SDRAM模式
  6. 發(fā)送正常運(yùn)行命令

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

具體上講,開(kāi)發(fā)者在芯片剛剛啟動(dòng)時(shí)(如Reset_Handler中)初始化SDRAM需要留心以下細(xì)節(jié):
  1. 由于SDRAM初始化函數(shù)使用系統(tǒng)堆?;蛉肿兞?,開(kāi)發(fā)者必須確保系統(tǒng)堆?;蛉肿兞克诘奈锢韮?nèi)存上電及時(shí)鐘使能。
  2. 在程序跳轉(zhuǎn)到主程序啟動(dòng)之前,全局變量未清零或初始化,如果在主函數(shù)之前執(zhí)行SDRAM初始化,開(kāi)發(fā)者必須手動(dòng)初始化變量。

舉個(gè)例子,在LPC5460x中,開(kāi)發(fā)者需要在SystemInit函數(shù)中初始化SDRAM,該函數(shù)(SystemInit)由Reset_Handler調(diào)用。在調(diào)用系統(tǒng)初始化之前,要通過(guò)設(shè)置AHBCLKCTRLSET0寄存器將SRAM時(shí)鐘使能。
Reset_Handler PROCEXPORT Reset_Handler [WEAK]IMPORT SystemInitIMPORT __main; clock control SRAM1/SRAM2/SRAM3 for stackLDR r0, = 0x40000220 ; AHBCLKCTRLSET0MOV r1, #0x38STR r1, [r0]LDR r0, =SystemInitBLX r0LDR r0, =__mainBX r0ENDP


SDRAM存儲(chǔ)器布局



當(dāng)使用SDRAM時(shí),外部存儲(chǔ)控制器(EMC)分配SDRAM一定的地址空間。開(kāi)發(fā)者可以使用鏈接描述文件將代碼或數(shù)據(jù)分配到SDRAM中。值得注意的是,鏈接器腳本編程在不同IDE之間是不同的。
以LPC5460x系列微控制器為例,SDRAM支持4個(gè)片選區(qū),每個(gè)片選區(qū)最大支持256MB空間。
SDRAM片選地址范圍
00xA0000000 - 0xA7FFFFFF
10xA8000000 - 0xAFFFFFFF
20xB0000000 - 0xB7FFFFFF
30xB8000000 - 0xBFFFFFFF

當(dāng)SDRAM的硬件連接使用SDRAM片選0的情況下,在KEIL平臺(tái)下,將加載在SPI FLASH的Coremark基準(zhǔn)測(cè)試程序拷貝到SDRAM中執(zhí)行需要以下幾步。(coremark基準(zhǔn)測(cè)試程序包括core_list_join.c,core_matrix.c,core_state.c及core_util.c)。
  1. 定義SDRAM區(qū)域,從0xA0000000開(kāi)始,大小為0x80000。定義SPI FLASH區(qū)域,大小為0x80000(SPI FLASH存儲(chǔ)器的起始地址為0x10000000)。
  2. 在C源碼中使用“SDRAM_Data” 和 “SDRAM_Function”屬性,標(biāo)記放在SDRAM區(qū)域中的數(shù)據(jù)或程序。(SDRAM_Data和SDRAM_Function只是文本名字)。
  3. 也可以將整個(gè)目標(biāo)文件的數(shù)據(jù)和程序段配置到SDRAM

#define m_spifi_start 0x10000000#define m_spifi_size 0x800000#define m_sdram_start 0xA0000000#define m_sdram_size 0x80000LR_m_text2 m_spifi_start m_spifi_size { ; load to SPIFILR_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)行程序,開(kāi)發(fā)者可能需要配置ARM內(nèi)核內(nèi)存保護(hù)單元(MPU)。
內(nèi)存保護(hù)單元(MPU)是一個(gè)可編程單元,用于定義內(nèi)存訪問(wèn)權(quán)限。當(dāng)MPU沒(méi)有使能時(shí),內(nèi)存地址空間具有默認(rèn)的訪問(wèn)權(quán)限。
如ARM Cortex?-M4器件通用用戶指南中所述,當(dāng)程序執(zhí)行SDRAM中的代碼且SDRAM內(nèi)存影射地址的默認(rèn)屬性為禁止執(zhí)行時(shí), 內(nèi)核就會(huì)產(chǎn)生HARDFAULT異常,且指令訪問(wèn)沖突標(biāo)志SCB->CFSR為 1,該異常表示處理器嘗試從不允許執(zhí)行的位置獲取指令。

因此,當(dāng)SDRAM被影射到默認(rèn)不可執(zhí)行的地址空間時(shí)(如在LPC5460x中,SDRAM影射到0xA0000000起始的地址),開(kāi)發(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)過(guò)程序運(yùn)行CoreMark性能基準(zhǔn)測(cè)試,總結(jié)了一點(diǎn)點(diǎn)經(jīng)驗(yàn),分享給大家
  1. SDRAM(16位帶寬)中的代碼執(zhí)行效率僅為在內(nèi)部SRAM中執(zhí)行效率性能40%,大約是內(nèi)部FLASH中運(yùn)行代碼性能的50%;
  2. 代碼在SDRAM中運(yùn)行時(shí),較高的CPU頻率(CPU沒(méi)有Cache)不能改善執(zhí)行效率,這時(shí)SDRAM帶寬成為系統(tǒng)性能的瓶頸。

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

END
來(lái)源:網(wǎng)絡(luò)版權(quán)歸原作者所有,如有侵權(quán),請(qǐng)聯(lián)系刪除。
嵌入式ARM

掃描二維碼,關(guān)注更多精彩內(nèi)容

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

瑞典烏普薩拉,2025年9月4日 — 全球領(lǐng)先的嵌入式系統(tǒng)開(kāi)發(fā)軟件解決方案供應(yīng)商IAR宣布,瑞薩最新推出的具備量產(chǎn)條件的RH850/U2A MCAL(微控制器抽象層)軟件包,已全面支持IAR的RH850工具鏈(v2.21...

關(guān)鍵字: MCU ADAS 電動(dòng)汽車

本屆年會(huì)將在上海(11月13-14日)、北京(11月19-20日)和深圳(11月27-28日)舉行,面向嵌入式設(shè)計(jì)工程師推出25門技術(shù)課程

關(guān)鍵字: 嵌入式 MCU 模擬

中國(guó)北京(2025年9月2日)—— 業(yè)界領(lǐng)先的半導(dǎo)體器件供應(yīng)商兆易創(chuàng)新GigaDevice(股票代碼 603986)受邀出席2025智能汽車基礎(chǔ)軟件生態(tài)大會(huì)暨第四屆中國(guó)汽車芯片大會(huì),并與國(guó)內(nèi)領(lǐng)先的AUTOSAR車用操作系...

關(guān)鍵字: 汽車電子 MCU 智能汽車

2025年8月26日,?Elexcon深圳國(guó)際電子展?在?深圳會(huì)展中心(福田)1號(hào)館?(展臺(tái)號(hào):1L30)盛大舉行。作為全球電子產(chǎn)業(yè)鏈的重要盛會(huì),展會(huì)匯聚創(chuàng)新技術(shù)與行業(yè)解決方案。米爾電子MYIR攜RZ系列核心板、開(kāi)發(fā)板等...

關(guān)鍵字: 核心板 開(kāi)發(fā)板 MCU

針對(duì)HMI應(yīng)用所需的段碼式LCD和電容式觸控進(jìn)行優(yōu)化,為電磁爐提供精準(zhǔn)控制;支持通過(guò)雙區(qū)閃存實(shí)現(xiàn)便捷、安全的OTA

關(guān)鍵字: MCU 智能家電 電磁爐

聚焦工業(yè)4.0及能源管理應(yīng)用對(duì)主控MCU的高性能需求,極海正式發(fā)布APM32F425/427系列高性能拓展型MCU,集合運(yùn)算性能、ADC性能、Flash控制器性能與通信接口四大維度革新,進(jìn)一步增強(qiáng)了EMC性能,重新定義C...

關(guān)鍵字: MCU 工業(yè)應(yīng)用 極海

MarketsandMarkets預(yù)測(cè),到2027年,全球嵌入式AI市場(chǎng)規(guī)模將超過(guò)200億美元,年復(fù)合增長(zhǎng)率高達(dá)30%。這一增長(zhǎng)背后,是對(duì)高算力、低功耗、實(shí)時(shí)性和安全性的迫切需求,以及技術(shù)碎片化與跨界融合的復(fù)雜挑戰(zhàn)。在這...

關(guān)鍵字: Renesas AI 瑞薩電子 嵌入式AI MCU MPU

全新產(chǎn)品滿足DLMS Suite2表計(jì)應(yīng)用安全法規(guī),提供豐富的通信選項(xiàng)、電容式觸摸界面,以及支持軟件更新的雙區(qū)閃存

關(guān)鍵字: MCU 閃存 恒溫器

由于邊緣AI是指在邊緣設(shè)備上部署和運(yùn)行AI模型,而不是將數(shù)據(jù)傳輸?shù)街醒敕?wù)器進(jìn)行處理。這種方式具有低延遲、高響應(yīng)速度、保護(hù)隱私和降低數(shù)據(jù)傳輸成本等優(yōu)勢(shì)。微控制器(MCU)作為電子設(shè)備的主控制芯片,在邊緣AI的發(fā)展中扮演著...

關(guān)鍵字: MCU AI

隨著在線會(huì)議、直播和游戲語(yǔ)音交流的普及,高質(zhì)量的音頻輸入設(shè)備變得越來(lái)越重要。為此,邊緣AI和智能音頻專家XMOS攜手其全球首家增值分銷商飛騰云科技,利用其集邊緣AI、DSP、MCU和靈活I(lǐng)/O于一顆芯片的xcore處理器...

關(guān)鍵字: AI DSP MCU
關(guān)閉