国产chinesehdxxxx老太婆,办公室玩弄爆乳女秘hd,扒开腿狂躁女人爽出白浆 ,丁香婷婷激情俺也去俺来也,ww国产内射精品后入国产

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

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

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

SDRAM初始化分為6個(gè)步驟及SDRAM存儲(chǔ)器布局

GReq_mcu168 ? 來(lái)源:未知 ? 2019-11-23 11:38 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

寫在前面


在使用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 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存儲(chǔ)器布局

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

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


					

SDRAM片選


					

地址范圍


					

0


					

0xA0000000 - 0xA7FFFFFF


					

1


					

0xA8000000 - 0xAFFFFFFF


					

2


					

0xB0000000 - 0xB7FFFFFF


					

3


					

0xB8000000 - 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 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)行程序,開(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 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)過(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ù)。


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

    關(guān)注

    146

    文章

    17970

    瀏覽量

    366532
  • SDRAM
    +關(guān)注

    關(guān)注

    7

    文章

    442

    瀏覽量

    56298

原文標(biāo)題:MCU怎么在擴(kuò)展的SDRAM上運(yùn)行程序?

文章出處:【微信號(hào):mcu168,微信公眾號(hào):硬件攻城獅】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    SDRAM理論基礎(chǔ)講解

    SDRAM的引腳,就必須要看SDRAM的datasheet。 三、學(xué)習(xí)SDRAM初始化的配置過(guò)程對(duì)于的初始化,也是需要參考官方文檔的。 對(duì)于
    發(fā)表于 03-26 14:35

    嵌入式存儲(chǔ)器的應(yīng)用:sDRAM硬件連接方案以及軟件接口的實(shí)現(xiàn)

    分為靜態(tài)隨機(jī)存儲(chǔ)器(SRAM)、動(dòng)態(tài)隨機(jī)存儲(chǔ)器(DRAM)及SDRAM。1個(gè)SRAM單元通常由4~6
    發(fā)表于 08-12 00:00

    SDRAM它是怎么工作的?

    結(jié)構(gòu)體一、SDRAM 同步動(dòng)態(tài)隨機(jī)存儲(chǔ)器(也是一個(gè)芯片)問(wèn)題:它出什么地方來(lái)的呢?為什么會(huì)用到它?它怎么工作的?stm32控制芯片內(nèi)部有一定大小的SRAM和FLASH作為內(nèi)存和程序儲(chǔ)存空間,但是有時(shí)候后可能程序比較大,內(nèi)存就不夠
    發(fā)表于 01-20 08:22

    嵌入式裸機(jī)之匯編初始化SDRAM實(shí)現(xiàn)過(guò)程

    1.SDRAM引入1.1 常見(jiàn)存儲(chǔ)器介紹:DRAM介紹同步動(dòng)態(tài)隨機(jī)存取內(nèi)存(synchronous dynamic random-access memory,簡(jiǎn)稱SDRAM),有一個(gè)
    發(fā)表于 05-16 15:03

    SDRAM存儲(chǔ)器部分電路圖

    SDRAM存儲(chǔ)器部分電路
    發(fā)表于 05-07 18:41 ?21次下載

    SDRAM控制的設(shè)計(jì)

    在很多通信芯片及系統(tǒng)的開(kāi)發(fā)中,常常需要用到存儲(chǔ)容量大、讀寫速度快的存儲(chǔ)器。在各種隨機(jī)存儲(chǔ)器件中,SDRAM的價(jià)格低、體積小、速度快、容量大,是比較理想的器件。但是,與SRAM相比較,
    發(fā)表于 11-28 19:51 ?5次下載
    <b class='flag-5'>SDRAM</b>控制<b class='flag-5'>器</b>的設(shè)計(jì)

    DRAM、SDRAM及DDR SDRAM之間的概念詳解

    DRAM (動(dòng)態(tài)隨機(jī)訪問(wèn)存儲(chǔ)器)對(duì)設(shè)計(jì)人員特別具有吸引力,因?yàn)樗峁┝藦V泛的性能,用于各種計(jì)算機(jī)和嵌入式系統(tǒng)的存儲(chǔ)系統(tǒng)設(shè)計(jì)中。本文概括闡述了DRAM 的概念,及介紹了SDRAM、DDR SD
    發(fā)表于 06-07 22:10 ?9.4w次閱讀

    SDRAM存儲(chǔ)器相關(guān)資料下載

    SDRAM存儲(chǔ)器相關(guān)資料下載
    發(fā)表于 05-02 11:46 ?49次下載
    <b class='flag-5'>SDRAM</b><b class='flag-5'>存儲(chǔ)器</b>相關(guān)資料下載

    FPGA讀寫SDRAM的實(shí)例和SDRAM的相關(guān)文章及一些SDRAM控制設(shè)計(jì)論文

    ,SDRAM的原理和時(shí)序,SDRAM控制,動(dòng)態(tài)隨即存儲(chǔ)器SDRAM模塊功能簡(jiǎn)介,基于FPGA的SDRA
    發(fā)表于 12-25 08:00 ?57次下載
    FPGA讀寫<b class='flag-5'>SDRAM</b>的實(shí)例和<b class='flag-5'>SDRAM</b>的相關(guān)文章及一些<b class='flag-5'>SDRAM</b>控制<b class='flag-5'>器</b>設(shè)計(jì)論文

    SDRAM存儲(chǔ)器模塊的簡(jiǎn)介

    SDRAM與 Flash不同,它不具有掉電保持?jǐn)?shù)據(jù)的特性,但其存取速度大大高于 Flash存儲(chǔ)器,且具有讀/寫的屬性,因此 SDRAM在系統(tǒng)中主要用作程序的運(yùn)行空間,數(shù)據(jù)及堆棧區(qū)。當(dāng)系統(tǒng)啟動(dòng)
    發(fā)表于 12-18 16:13 ?12次下載
    <b class='flag-5'>SDRAM</b><b class='flag-5'>存儲(chǔ)器</b>模塊的簡(jiǎn)介

    EE-286:將SDRAM存儲(chǔ)器連接到SHARC?處理

    EE-286:將SDRAM存儲(chǔ)器連接到SHARC?處理
    發(fā)表于 04-28 09:53 ?4次下載
    EE-286:將<b class='flag-5'>SDRAM</b><b class='flag-5'>存儲(chǔ)器</b>連接到SHARC?處理<b class='flag-5'>器</b>

    STM32H750_FMC_SDRAM 初始化流程總結(jié)

    STM32H750_FMC_SDRAM使用STM32CUBEMX 初始化FMC部分,SDRAM 關(guān)于延時(shí)部分參數(shù)模式寄存#define SDRAM
    發(fā)表于 12-29 18:49 ?2次下載
    STM32H750_FMC_<b class='flag-5'>SDRAM</b> <b class='flag-5'>初始化</b>流程總結(jié)

    STM32H7實(shí)現(xiàn)BootLoader內(nèi)SDRAM初始化注意事項(xiàng)

    Function Implementation:在 ArtPi 的環(huán)境下,實(shí)現(xiàn)一個(gè)簡(jiǎn)單的 BootLoader,該 BootLoader 實(shí)現(xiàn)了 QSPI 和 SDRAM 功能的初始化
    的頭像 發(fā)表于 06-07 15:51 ?4544次閱讀
    STM32H7實(shí)現(xiàn)BootLoader內(nèi)<b class='flag-5'>SDRAM</b>的<b class='flag-5'>初始化</b>注意事項(xiàng)

    SDRAM工作原理 SDRAM布局布線說(shuō)明

    SDRAM全稱Synchronous Dynamic RAM,同步動(dòng)態(tài)隨機(jī)存儲(chǔ)器。首先,它是RAM,即隨機(jī)存儲(chǔ)器的一種。
    發(fā)表于 08-08 15:10 ?2922次閱讀
    <b class='flag-5'>SDRAM</b>工作原理 <b class='flag-5'>SDRAM</b><b class='flag-5'>布局</b>布線說(shuō)明

    SDRAM同步動(dòng)態(tài)隨機(jī)存儲(chǔ)器的操作說(shuō)明

    SDRAM是做嵌入式系統(tǒng)中,常用是的緩存數(shù)據(jù)的器件?;靖拍钊缦拢ㄗ⒁鈪^(qū)分幾個(gè)主要常見(jiàn)存儲(chǔ)器之間的差異)。
    的頭像 發(fā)表于 11-05 17:35 ?1128次閱讀
    <b class='flag-5'>SDRAM</b>同步動(dòng)態(tài)隨機(jī)<b class='flag-5'>存儲(chǔ)器</b>的操作說(shuō)明