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

當(dāng)前位置:首頁(yè) > 技術(shù)學(xué)院 > 技術(shù)前線
[導(dǎo)讀]對(duì)于獨(dú)立的嵌入式系統(tǒng),需要把程序存入non-volitale存儲(chǔ)單元中,常用的也就是flash。但是程序在flash中運(yùn)行相對(duì)在RAM中行,速度會(huì)變慢很多,具體有多慢,拿28335來(lái)說(shuō)吧,假設(shè)系統(tǒng)時(shí)鐘為150MHz,在RAM中運(yùn)行時(shí)頻率還是150MHz,而放在flash中,頻率會(huì)降到90-95MHz,參照Ti手冊(cè)SPRA958L,這對(duì)于有些對(duì)實(shí)時(shí)性要求較高的函數(shù)功能,是不可接受的。所以在系統(tǒng)上電時(shí),把對(duì)實(shí)時(shí)性要求高的函數(shù)轉(zhuǎn)移到RAM中去。

嵌入式軟件中經(jīng)常要存儲(chǔ)一些非易失參數(shù),例如用戶設(shè)置、校準(zhǔn)參數(shù)、設(shè)備運(yùn)行參數(shù)等,通常情況下我們都會(huì)選擇存儲(chǔ)在EEPROM或者SPI-FLASH中。在削減成本考量的情況下,我們可以把存儲(chǔ)器省下來(lái),參數(shù)存儲(chǔ)在內(nèi)部flash中,畢竟就算每片減少一塊錢,量大后還是非??捎^的。

一.將DSP的Flash里面的函數(shù)轉(zhuǎn)移到RAM中

對(duì)于獨(dú)立的嵌入式系統(tǒng),需要把程序存入non-volitale存儲(chǔ)單元中,常用的也就是flash。但是程序在flash中運(yùn)行相對(duì)在RAM中行,速度會(huì)變慢很多,具體有多慢,拿28335來(lái)說(shuō)吧,假設(shè)系統(tǒng)時(shí)鐘為150MHz,在RAM中運(yùn)行時(shí)頻率還是150MHz,而放在flash中,頻率會(huì)降到90-95MHz,參照Ti手冊(cè)SPRA958L,這對(duì)于有些對(duì)實(shí)時(shí)性要求較高的函數(shù)功能,是不可接受的。所以在系統(tǒng)上電時(shí),把對(duì)實(shí)時(shí)性要求高的函數(shù)轉(zhuǎn)移到RAM中去。

下面以initflash函數(shù)為例,具體步驟如下:

(1)、將函數(shù)定位到section:

#pragma CODE_SECTION(InitFlash, "secureRamFuncs")

當(dāng)遇到InitFlash(),就到段secureRamFuncs去運(yùn)行。

當(dāng)有多個(gè)函數(shù)需要轉(zhuǎn)移時(shí),重復(fù)使用#pragma CODE_SECTION(“函數(shù)名", "secureRamFuncs")即可。

即使有多個(gè)#pragma CODE_SECTION,后面的步驟只需要一次。

(2)、section分配到memory(紅色為memory)。

意思是到FLASH去下載InitFlash(),下載到SECURE_RAM,然后要到SECURE_RAM去運(yùn)行程序,這個(gè)過(guò)程給出了下載地址和目標(biāo)地址。注意此時(shí)SECURE_RAM中還沒(méi)有代碼。

1. SECTIONS

2. {

3. /*** User Defined Sections ***/

4. secureRamFuncs: LOAD = FLASH,PAGE = 0

5. RUN =SECURE_RAM, PAGE = 0

6. //定義FLASH和SECURE_RAM的首地址secureRamFuncs_loadstart和secureRamFuncs_loadstart以代替絕對(duì)地址

7. LOAD_START(_secureRamFuncs_loadstart),

8. LOAD_SIZE(_secureRamFuncs_loadsize),

9. RUN_START(_secureRamFuncs_runstart),

10. }

(3)、用memcpy()將經(jīng)過(guò)#pragmaCODE_SECTION設(shè)定的函數(shù)從FLASH弄到SECURE_RAM中去。注意不是將FLASH的東西全部弄到SECURE_RAM中。

1. #include

2. //實(shí)際應(yīng)用中這一部分聲明可有可無(wú)

3. extern unsigned intsecureRamFuncs_loadstart;

4. extern unsigned intsecureRamFuncs_loadsize;

5. extern unsigned intsecureRamFuncs_runstart;

6. void main(void)

7. {

8. /* Copy the secureRamFuncs section */

9. memcpy(&secureRamFuncs_runstart,&secureRamFuncs_loadstart,(Uint32)&secureRamFuncs_loadsize);

10. /* Initialize the on-chip flash registers*/

11. InitFlash();

12. }

二.將MCU的內(nèi)嵌Flash里的部分代碼運(yùn)行在 RAM 中

MCU 異于資源豐富的linux 平臺(tái)。 MCU(如: 基于Cortex V6M 的Cortex M0+ 等) Code通常運(yùn)行在內(nèi)嵌Flash中。 在某些特定應(yīng)用場(chǎng)合,需要將部分函數(shù)運(yùn)行于RAM 中。為解決次問(wèn)題,筆者實(shí)現(xiàn)了一種解法,具體做法如下:

1. 實(shí)現(xiàn)要運(yùn)行在RAM的 routine, 本routine 使用純匯編實(shí)現(xiàn), 如:

__asm void program_word2addr(uint32_t addr, uint32_t data)

{

push {r3, r4, r5, lr} ;save some regsiters

/*your code for this routine*/

pop {r3, r4, r5, pc}

}

2.編譯時(shí),采用code 與運(yùn)行位置無(wú)關(guān)的編譯選項(xiàng) 如 (Keil --apcs /ropi/rwpi), 生成 *.axf;

3.通過(guò)fromelf -c 將生成 *.axf 反匯編,找到對(duì)應(yīng)program_word2addr 實(shí)現(xiàn)部分, 并將routine 對(duì)應(yīng)的binary code Copy 到所要應(yīng)用的 Code 中,以只讀數(shù)組的形式出現(xiàn):

如:

const staic uint16_t s_flashProg2AddressCode[16] = {...., ....}

4.定義 一個(gè)全局?jǐn)?shù)組, 如 static uint16_t g_code[16], size正好等于 s_flashProg2AddressCode的長(zhǎng)度;

5. 定義一個(gè)函數(shù)指針, 如 static void (*callFlashPrg2Address)(uint32_t addr, uint32_t data)

6.定義一個(gè)函數(shù)實(shí)現(xiàn)將Code 運(yùn)行與 RAM如:

void run_prgcode_onram(uint32_t addr, uint32_t data)

{

memcpy(g_code,s_flashProg2AddressCode,32 );

callFlashPrg2Address = (void (*)(uint32_t addr, uint32_t data))((uin32_t)g_code + 1);

callFlashPrg2Address (address, data);

}

run_prgcode_onram, 便可以將program_word2addr 運(yùn)行于RAM中。

callFlashPrg2Address = (void (*)(uint32_t addr, uint32_t data))((uin32_t)g_code + 1); +1 的目的,時(shí)由于運(yùn)行平臺(tái)為 Cortex V6M , 采用的thumb指令集,根據(jù)ARM Spec 要求完成。

callFlashPrg2Address (address, data); 則是實(shí)現(xiàn)RAM運(yùn)行program_word2addr 的關(guān)鍵所在。

本站聲明: 本文章由作者或相關(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)系本站刪除。
換一批
延伸閱讀

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

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

上海2025年9月5日 /美通社/ -- 由紐倫堡會(huì)展(上海)有限公司舉辦的上海國(guó)際嵌入式會(huì)議將于 2025 年 10 月 16-17 日在上海世博展覽館舉辦。 此次會(huì)議將由三個(gè)版塊組成:嵌入式技術(shù)會(huì)議、汽...

關(guān)鍵字: 嵌入式 CE CHINA EMBEDDED

從外部看,電子系統(tǒng)仿佛一個(gè)統(tǒng)一的學(xué)科或設(shè)備,各組成部分協(xié)同工作,渾然一體。然而揭開(kāi)表象,其內(nèi)在卻是另一番景象:一個(gè)碎片化、多層次的世界——其中每一層都獨(dú)立且復(fù)雜,衍生出各自特有的工具、專家、工作流程,甚至哲學(xué)體系。

關(guān)鍵字: 嵌入式 電子系統(tǒng) 半導(dǎo)體

8位單片機(jī)在嵌入式設(shè)計(jì)領(lǐng)域已經(jīng)成為半個(gè)多世紀(jì)以來(lái)的主流選擇。盡管嵌入式系統(tǒng)市場(chǎng)日益復(fù)雜,8位單片機(jī)依然不斷發(fā)展,積極應(yīng)對(duì)新的挑戰(zhàn)和系統(tǒng)需求。如今,Microchip推出的8位PIC?和AVR?單片機(jī)系列,配備了先進(jìn)的獨(dú)立...

關(guān)鍵字: 單片機(jī) 嵌入式 CPU

深圳2025年8月28日 /美通社/ -- 8月26日,2025 ELEXCON深圳國(guó)際電子展盛大啟幕。本屆大會(huì)以"All for AI"為主題,深圳市德...

關(guān)鍵字: AI 工業(yè)級(jí) SSD 嵌入式

深圳2025年8月26日 /美通社/ -- 8月26日,由博聞創(chuàng)意會(huì)展主辦的 第22屆深圳國(guó)際電子展暨嵌入式展(elexcon2025)在深圳(福田)會(huì)展中心隆重開(kāi)幕。 作為中國(guó)電子與嵌入式技術(shù)領(lǐng)域的專業(yè)大展,本屆展會(huì)...

關(guān)鍵字: 嵌入式 電子 高通 AI

模塊化設(shè)計(jì)作為一種將系統(tǒng)拆分為獨(dú)立、可復(fù)用組件的方法,能夠在低代碼平臺(tái)中實(shí)現(xiàn)功能的靈活組合,并最大限度地提升系統(tǒng)性能。本文將探討如何通過(guò)模塊化設(shè)計(jì),使得低代碼平臺(tái)既能快速適應(yīng)變化,又能保持高效穩(wěn)定的運(yùn)行。

關(guān)鍵字: 模塊化設(shè)計(jì) 嵌入式

CPU親和度通過(guò)限制進(jìn)程或線程可以運(yùn)行的CPU核心集合,使得它們只能在指定的CPU核心上執(zhí)行。這可以減少CPU緩存的失效次數(shù),提高緩存命中率,從而提升系統(tǒng)性能。

關(guān)鍵字: Linux 嵌入式

加密算法分對(duì)稱加密和非對(duì)稱算法,其中對(duì)稱加密算法的加密與解密密鑰相同,非對(duì)稱加密算法的加密密鑰與解密密鑰不同,此外,還有一類不需要密鑰的散列算法。

關(guān)鍵字: 算法 嵌入式

從本質(zhì)上講,算法是一種有條不紊、分步驟解決問(wèn)題或完成任務(wù)的方法。無(wú)論是簡(jiǎn)單的數(shù)字相加公式,還是復(fù)雜的機(jī)器學(xué)習(xí)協(xié)議,算法都是軟件應(yīng)用的基礎(chǔ),確保任務(wù)能夠高效有效地執(zhí)行。

關(guān)鍵字: 算法 嵌入式
關(guān)閉