日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

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


在使用MCU的嵌入式系統(tǒng)設(shè)計中,當程序或者數(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個步驟。
  1. 配置EMC寄存器的SDRAM時鐘頻率、字節(jié)順序和時序參數(shù)。
    SDRAM的時序比較復雜,用戶需要通過查閱相關(guān)SDRAM芯片的手冊獲得時序參數(shù)(如刷新周期、預充電命令周期、自刷新退出時間、寫恢復時間等等)。
  2. 發(fā)送NOP命令
  3. 發(fā)送預充電命令
  4. 發(fā)送兩次自動刷新命令
  5. 設(shè)置SDRAM模式
  6. 發(fā)送正常運行命令

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

具體上講,開發(fā)者在芯片剛剛啟動時(如Reset_Handler中)初始化SDRAM需要留心以下細節(jié):
  1. 由于SDRAM初始化函數(shù)使用系統(tǒng)堆棧或全局變量,開發(fā)者必須確保系統(tǒng)堆?;蛉肿兞克诘奈锢韮?nèi)存上電及時鐘使能。
  2. 在程序跳轉(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 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存儲器布局



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

當SDRAM的硬件連接使用SDRAM片選0的情況下,在KEIL平臺下,將加載在SPI FLASH的Coremark基準測試程序拷貝到SDRAM中執(zhí)行需要以下幾步。(coremark基準測試程序包括core_list_join.c,core_matrix.c,core_state.c及core_util.c)。
  1. 定義SDRAM區(qū)域,從0xA0000000開始,大小為0x80000。定義SPI FLASH區(qū)域,大小為0x80000(SPI FLASH存儲器的起始地址為0x10000000)。
  2. 在C源碼中使用“SDRAM_Data” 和 “SDRAM_Function”屬性,標記放在SDRAM區(qū)域中的數(shù)據(jù)或程序。(SDRAM_Data和SDRAM_Function只是文本名字)。
  3. 也可以將整個目標文件的數(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中運行程序,開發(fā)者可能需要配置ARM內(nèi)核內(nèi)存保護單元(MPU)。
內(nèi)存保護單元(MPU)是一個可編程單元,用于定義內(nèi)存訪問權(quán)限。當MPU沒有使能時,內(nèi)存地址空間具有默認的訪問權(quán)限。
如ARM Cortex?-M4器件通用用戶指南中所述,當程序執(zhí)行SDRAM中的代碼且SDRAM內(nèi)存影射地址的默認屬性為禁止執(zhí)行時, 內(nèi)核就會產(chǎn)生HARDFAULT異常,且指令訪問沖突標志SCB->CFSR為 1,該異常表示處理器嘗試從不允許執(zhí)行的位置獲取指令。

因此,當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)驗,分享給大家
  1. SDRAM(16位帶寬)中的代碼執(zhí)行效率僅為在內(nèi)部SRAM中執(zhí)行效率性能40%,大約是內(nèi)部FLASH中運行代碼性能的50%;
  2. 代碼在SDRAM中運行時,較高的CPU頻率(CPU沒有Cache)不能改善執(zhí)行效率,這時SDRAM帶寬成為系統(tǒng)性能的瓶頸。

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

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

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

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

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設(shè)備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅(qū)動電源設(shè)計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設(shè)計成為提升電機驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設(shè)備的使用壽命。然而,在實際應(yīng)用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設(shè)計、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設(shè)計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉