當(dāng)前位置:首頁(yè) > 公眾號(hào)精選 > 技術(shù)讓夢(mèng)想更偉大
[導(dǎo)讀]關(guān)注、星標(biāo)公眾號(hào),直達(dá)精彩內(nèi)容ID:技術(shù)讓夢(mèng)想更偉大整理:李肖遙內(nèi)存管理對(duì)應(yīng)用程序和操作系統(tǒng)來(lái)說(shuō)都非常重要?,F(xiàn)在很多的程序漏洞和運(yùn)行崩潰都和內(nèi)存分配使用錯(cuò)誤有關(guān)。FreeRTOS操作系統(tǒng)將內(nèi)核與內(nèi)存管理分開實(shí)現(xiàn),操作系統(tǒng)內(nèi)核僅規(guī)定了必要的內(nèi)存管理函數(shù)原型,而不關(guān)心這些內(nèi)存管理函數(shù)...


關(guān)注、星標(biāo)公眾號(hào),直達(dá)精彩內(nèi)容

ID:技術(shù)讓夢(mèng)想更偉大

整理:李肖遙


內(nèi)存管理對(duì)應(yīng)用程序和操作系統(tǒng)來(lái)說(shuō)都非常重要。現(xiàn)在很多的程序漏洞和運(yùn)行崩潰都和內(nèi)存分配使用錯(cuò)誤有關(guān)。

FreeRTOS操作系統(tǒng)將內(nèi)核與內(nèi)存管理分開實(shí)現(xiàn),操作系統(tǒng)內(nèi)核僅規(guī)定了必要的內(nèi)存管理函數(shù)原型,而不關(guān)心這些內(nèi)存管理函數(shù)是如何實(shí)現(xiàn)的。

這樣做大有好處,可以增加系統(tǒng)的靈活性:不同的應(yīng)用場(chǎng)合可以使用不同的內(nèi)存分配實(shí)現(xiàn),選擇對(duì)自己更有利的內(nèi)存管理策略。

比如對(duì)于安全型的嵌入式系統(tǒng),通常不允許動(dòng)態(tài)內(nèi)存分配,那么可以采用非常簡(jiǎn)單的內(nèi)存管理策略,一經(jīng)申請(qǐng)的內(nèi)存,甚至不允許被釋放。

在滿足設(shè)計(jì)要求的前提下,系統(tǒng)越簡(jiǎn)單越容易做的更安全。

再比如一些復(fù)雜應(yīng)用,要求動(dòng)態(tài)的申請(qǐng)、釋放內(nèi)存操作,那么也可以設(shè)計(jì)出相對(duì)復(fù)雜的內(nèi)存管理策略,允許動(dòng)態(tài)分配和動(dòng)態(tài)釋放。

FreeRTOS內(nèi)核規(guī)定的幾個(gè)內(nèi)存管理函數(shù)原型為:」

void *pvPortMalloc( size_t xSize )?:內(nèi)存申請(qǐng)函數(shù)
void vPortFree( void *pv )?:內(nèi)存釋放函數(shù)
void vPortInitialiseBlocks( void )?:初始化內(nèi)存堆函數(shù)
size_t xPortGetFreeHeapSize( void )?:獲取當(dāng)前未分配的內(nèi)存堆大小
size_t xPortGetMinimumEverFreeHeapSize( void ):獲取未分配的內(nèi)存堆歷史最小值
FreeRTOS提供了5種內(nèi)存管理實(shí)現(xiàn),有簡(jiǎn)單也有復(fù)雜的,可以應(yīng)用于絕大多數(shù)場(chǎng)合。

它們位于下載包目錄*...\FreeRTOS\Source\portable\MemMang*中,文件名分別為:heap_1.c、heap_2.c、heap_3.c、heap_4.c、heap_5.c。

我在《FreeRTOS系列第8篇---FreeRTOS內(nèi)存管理》這篇文章中介紹了這5種內(nèi)存管理的特性以及各自應(yīng)用的場(chǎng)合,今天我們要分析它們的實(shí)現(xiàn)方法。

FreeRTOS提供的內(nèi)存管理都是從內(nèi)存堆中分配內(nèi)存的。默認(rèn)情況下,F(xiàn)reeRTOS內(nèi)核創(chuàng)建任務(wù)、隊(duì)列、信號(hào)量、事件組、軟件定時(shí)器都是借助內(nèi)存管理函數(shù)從內(nèi)存堆中分配內(nèi)存。

最新的FreeRTOS版本(V9.0.0及其以上版本)可以完全使用靜態(tài)內(nèi)存分配方法,也就是不使用任何內(nèi)存堆。

對(duì)于heap_1.c、heap_2.c和heap_4.c這三種內(nèi)存管理策略,內(nèi)存堆實(shí)際上是一個(gè)很大的數(shù)組,定義為:

static?uint8_t?ucHeap[?configTOTAL_HEAP_SIZE?];
其中宏configTOTAL_HEAP_SIZE用來(lái)定義內(nèi)存堆的大小,這個(gè)宏在FreeRTOSConfig.h中設(shè)置。

對(duì)于heap_3.c,這種策略只是簡(jiǎn)單的包裝了標(biāo)準(zhǔn)庫(kù)中的malloc()和free()函數(shù),包裝后的malloc()和free()函數(shù)具備線程保護(hù)。因此,內(nèi)存堆需要通過(guò)編譯器或者啟動(dòng)文件設(shè)置堆空間。

heap_5.c比較有趣,它允許程序設(shè)置多個(gè)非連續(xù)內(nèi)存堆,比如需要快速訪問(wèn)的內(nèi)存堆設(shè)置在片內(nèi)RAM,稍微慢速訪問(wèn)的內(nèi)存堆設(shè)置在外部RAM。每個(gè)內(nèi)存堆的起始地址和大小由應(yīng)用程序設(shè)計(jì)者定義。

1. heap_1.c

這是5個(gè)內(nèi)存管理策略中最簡(jiǎn)單的一個(gè),我們稱為第一個(gè)內(nèi)存管理策略,它簡(jiǎn)單到只能申請(qǐng)內(nèi)存。

是的,跟你想的一樣,一旦申請(qǐng)成功后,這塊內(nèi)存再也不能被釋放。

對(duì)于大多數(shù)嵌入式系統(tǒng),特別是對(duì)安全要求高的嵌入式系統(tǒng),這種內(nèi)存管理策略很有用,因?yàn)閷?duì)系統(tǒng)軟件來(lái)說(shuō),邏輯越簡(jiǎn)單越容易兼顧安全。

實(shí)際上,大多數(shù)的嵌入式系統(tǒng)并不需要?jiǎng)討B(tài)刪除任務(wù)、信號(hào)量、隊(duì)列等,而是在初始化的時(shí)候一次性創(chuàng)建好,便一直使用,永遠(yuǎn)不用刪除。

所以這個(gè)內(nèi)存管理策略實(shí)現(xiàn)簡(jiǎn)潔、安全可靠,使用的非常廣泛。我對(duì)這個(gè)對(duì)內(nèi)存管理策略也情有獨(dú)鐘。

我們可以將第一種內(nèi)存管理看作是切面包:初始化的內(nèi)存就像一根完整的長(zhǎng)棍面包,每次申請(qǐng)內(nèi)存,就從一端切下適當(dāng)長(zhǎng)度的面包返還給申請(qǐng)者,直到面包被分配完畢,就這么簡(jiǎn)單。

這個(gè)內(nèi)存管理策略使用兩個(gè)局部靜態(tài)變量來(lái)跟蹤內(nèi)存分配,變量定義為:

static?size_t?xNextFreeByte?=?(?size_t?)?0;
static?uint8_t?*pucAlignedHeap?=?NULL;
其中,變量xNextFreeByte記錄已經(jīng)分配的內(nèi)存大小,用來(lái)定位下一個(gè)空閑的內(nèi)存堆位置。

因?yàn)閮?nèi)存堆實(shí)際上是一個(gè)大數(shù)組,我們只需要知道已分配內(nèi)存的大小,就可以用它作為偏移量找到未分配內(nèi)存的起始地址。

變量xNextFreeByte被初始化為0,然后每次申請(qǐng)內(nèi)存成功后,都會(huì)增加申請(qǐng)內(nèi)存的字節(jié)數(shù)目。

變量pucAlignedHeap指向?qū)R后的內(nèi)存堆起始位置。「為什么要對(duì)齊?」

這是因?yàn)榇蠖鄶?shù)硬件訪問(wèn)內(nèi)存對(duì)齊的數(shù)據(jù)速度會(huì)更快。

為了提高性能,F(xiàn)reeRTOS會(huì)進(jìn)行對(duì)齊操作,不同的硬件架構(gòu)對(duì)齊操作也不盡相同,對(duì)于Cortex-M3架構(gòu),進(jìn)行8字節(jié)對(duì)齊。

我們來(lái)看一下第一種內(nèi)存管理策略對(duì)外提供的API函數(shù)。

1.1內(nèi)存申請(qǐng):pvPortMalloc()

「函數(shù)源碼為:」

void?*pvPortMalloc(?size_t?xWantedSize?)
{
void?*pvReturn?=?NULL;
static?uint8_t?*pucAlignedHeap?=?NULL;
?
????/*?確保申請(qǐng)的字節(jié)數(shù)是對(duì)齊字節(jié)數(shù)的倍數(shù)?*/
????#if(?portBYTE_ALIGNMENT?!=?1?)
????{
????????if(?xWantedSize?
本站聲明: 本文章由作者或相關(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)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉