Buddy算法在μC/OSII動(dòng)態(tài)內(nèi)存管理改進(jìn)中的應(yīng)用分析
2017-10-26 |
rar |
0.4 MB |
次下載 |
1積分
資料介紹
1 內(nèi)存管理概述
內(nèi)存管理是操作系統(tǒng)的中心任務(wù)之一,其主要任務(wù)是組織內(nèi)存以容納內(nèi)核和待執(zhí)行程序,跟蹤當(dāng)前內(nèi)存的使用情況,在需要時(shí)為進(jìn)程分配內(nèi)存,使用完畢后釋放并回收內(nèi)存。目前嵌入式系統(tǒng)中常用的內(nèi)存管理策略主要有兩種--靜態(tài)內(nèi)存分配和動(dòng)態(tài)內(nèi)存分配。
靜態(tài)內(nèi)存分配: 編譯或鏈接時(shí)將所需內(nèi)存分配好,程序運(yùn)行起來后所分配的內(nèi)存不釋放。對于實(shí)時(shí)性和可靠性要求極高的系統(tǒng),不允許延遲或者分配失效,必須采用靜態(tài)內(nèi)存分配的方式。
動(dòng)態(tài)內(nèi)存分配: 根據(jù)程序執(zhí)行過程中所需內(nèi)存的大小而動(dòng)態(tài)分配內(nèi)存的策略。此方案按需分配內(nèi)存,避免了靜態(tài)分配中的內(nèi)存浪費(fèi),靈活性比較強(qiáng),給程序的實(shí)現(xiàn)帶來了很大方便。缺點(diǎn)是容易造成內(nèi)存碎片,且容易造成程序響應(yīng)不及時(shí)等問題。
綜上所述,靜態(tài)內(nèi)存分配和動(dòng)態(tài)內(nèi)存分配各有優(yōu)點(diǎn),出于嵌入式系統(tǒng)可靠性、實(shí)時(shí)性及成本、功耗的考慮,如何在兩種方案中作出平衡的選擇是令嵌入式操作系統(tǒng)設(shè)計(jì)者頭疼的事。一般的嵌入式操作系統(tǒng)都是兩種方案的高效結(jié)合,μC/OSII也不例外。除此之外,嵌入式操作系統(tǒng)對內(nèi)存的分配還有以下幾點(diǎn)要求:
?、?可靠性。內(nèi)存分配的請求必須得到滿足,如果分配失敗可能會(huì)帶來災(zāi)難性的后果。比如,航天飛機(jī)的嵌入式操作系統(tǒng)若發(fā)生內(nèi)存分配失效,損失是不可估量的。
② 快速性。嵌入式系統(tǒng)對實(shí)時(shí)性的保證,要求簡單、快速地分配內(nèi)存。
?、?高效性。嵌入式系統(tǒng)中內(nèi)存是一種有限、昂貴的資源,內(nèi)存分配要盡可能地減少浪費(fèi)。
μC/OSII作為一種典型的嵌入式操作系統(tǒng),其內(nèi)存管理同樣要滿足以上3點(diǎn)要求,下面簡單介紹μC/OSII的內(nèi)存管理策略,并分析其不足之處。
2 μC/OSII動(dòng)態(tài)內(nèi)存管理方案及不足
2.1 μC/OSII內(nèi)存管理方案簡介
μC/OSII內(nèi)存管理模塊主要由一個(gè)數(shù)據(jù)結(jié)構(gòu)體和5個(gè)函數(shù)組成:
◆ 內(nèi)存控制塊數(shù)據(jù)結(jié)構(gòu)OS_MEM;
◆ 內(nèi)存分區(qū)創(chuàng)建函數(shù)OSMemCreate(void *addr, INT32U nblks, INT32U blksize, INT8U *err);
◆ 內(nèi)存塊分配函數(shù)OSMemGet(OS_MEM *pmem , INT8U *err);
◆ 內(nèi)存塊釋放函數(shù)OSMemPut(OS_MEM *pmem , void *pblk);
◆ 內(nèi)存分區(qū)狀態(tài)查詢函數(shù)OSMemQuery(OS_MEM *pmem, OS_MEM_DATA *p_mem_data);
◆ 內(nèi)存控制塊鏈表初始化函數(shù)OSMemInit(void)。
μC/OSII用一個(gè)內(nèi)存控制塊(OS_MEM)來管理內(nèi)存分區(qū),主要通過以下4步來管理:
?、?內(nèi)存控制塊鏈表初始化函數(shù)OSMemInit()負(fù)責(zé)創(chuàng)建空內(nèi)存控制塊結(jié)構(gòu)的鏈表,鏈表長度由內(nèi)核OS_CFG.H文件中定義的OS_MAX_MEM_PART宏確定。
② 內(nèi)存塊創(chuàng)建函數(shù)OSMemCreate()先從空內(nèi)存控制塊結(jié)構(gòu)鏈表上獲取一個(gè)空的內(nèi)存控制根塊結(jié)構(gòu),根據(jù)用戶需要內(nèi)存塊的大小來創(chuàng)建分區(qū)。一個(gè)分區(qū)中含有相同大小的內(nèi)存塊,各內(nèi)存塊也是通過鏈表鏈接起來,而不同分區(qū)中的內(nèi)存塊大小一般不同,如圖1所示的PartitiON # 1和Partition # 2中內(nèi)存塊的大小是不同的。

圖1 μC/OSII通過內(nèi)存控制塊管理內(nèi)存
③ 內(nèi)存塊分配函數(shù)OSMemGet()通過從內(nèi)存控制塊鏈表中找到能夠滿足自己內(nèi)存塊需要的內(nèi)存控制塊,然后從這個(gè)內(nèi)存控制塊指向的分區(qū)鏈表首部得到自己需要的內(nèi)存塊。
?、?內(nèi)存塊釋放函數(shù)OSMemPut()負(fù)責(zé)回收內(nèi)存塊。當(dāng)應(yīng)用程序不再使用某一個(gè)內(nèi)存塊時(shí),必須及時(shí)把它釋放,并放回到相應(yīng)的內(nèi)存分區(qū)中。
2.2 μC/OSII內(nèi)存管理方案的不足之處
如前所述,μC/OSII的內(nèi)存管理方案簡短精煉,僅百余行代碼,5個(gè)函數(shù)就能勝任。然而考慮到第1節(jié)提到的嵌入式系統(tǒng)對內(nèi)存管理策略的3個(gè)要求,μC/OSII的內(nèi)存管理策略存在以下不足之處:
?、?原μC/OSII內(nèi)存管理方案可靠性不高。因?yàn)樵桨钢懈鲀?nèi)存分區(qū)之間是孤立的,沒有聯(lián)系。一個(gè)內(nèi)存分區(qū)上的內(nèi)存塊用完時(shí),不能利用其他分區(qū)上的內(nèi)存塊,而只是簡單地報(bào)錯(cuò),從而使系統(tǒng)可靠性大大降低。在內(nèi)存塊大小及需求量不確定的場合,如果經(jīng)常發(fā)生內(nèi)存申請得不到滿足的情況,是嵌入式系統(tǒng)所不能容忍的。
?、?原μC/OSII內(nèi)存管理方案中內(nèi)存分配不夠靈活。舉個(gè)例子來說,一個(gè)應(yīng)用程序需要大小為1 KB、512 B、256 B三種內(nèi)存塊,原方案有兩種解決方案,一是創(chuàng)建一個(gè)內(nèi)存塊大小為1 KB的內(nèi)存分區(qū),內(nèi)存塊數(shù)目至少為3個(gè);二是創(chuàng)建3個(gè)內(nèi)存分區(qū),內(nèi)存塊大小分別為1 KB、512 B、256 B。方案一創(chuàng)建了較少分區(qū),性能有保證,但造成內(nèi)存資源的浪費(fèi);方案二雖然沒有浪費(fèi)內(nèi)存,但卻調(diào)用3次OS_MemCreate()函數(shù),效率較低。
內(nèi)存管理是操作系統(tǒng)的中心任務(wù)之一,其主要任務(wù)是組織內(nèi)存以容納內(nèi)核和待執(zhí)行程序,跟蹤當(dāng)前內(nèi)存的使用情況,在需要時(shí)為進(jìn)程分配內(nèi)存,使用完畢后釋放并回收內(nèi)存。目前嵌入式系統(tǒng)中常用的內(nèi)存管理策略主要有兩種--靜態(tài)內(nèi)存分配和動(dòng)態(tài)內(nèi)存分配。
靜態(tài)內(nèi)存分配: 編譯或鏈接時(shí)將所需內(nèi)存分配好,程序運(yùn)行起來后所分配的內(nèi)存不釋放。對于實(shí)時(shí)性和可靠性要求極高的系統(tǒng),不允許延遲或者分配失效,必須采用靜態(tài)內(nèi)存分配的方式。
動(dòng)態(tài)內(nèi)存分配: 根據(jù)程序執(zhí)行過程中所需內(nèi)存的大小而動(dòng)態(tài)分配內(nèi)存的策略。此方案按需分配內(nèi)存,避免了靜態(tài)分配中的內(nèi)存浪費(fèi),靈活性比較強(qiáng),給程序的實(shí)現(xiàn)帶來了很大方便。缺點(diǎn)是容易造成內(nèi)存碎片,且容易造成程序響應(yīng)不及時(shí)等問題。
綜上所述,靜態(tài)內(nèi)存分配和動(dòng)態(tài)內(nèi)存分配各有優(yōu)點(diǎn),出于嵌入式系統(tǒng)可靠性、實(shí)時(shí)性及成本、功耗的考慮,如何在兩種方案中作出平衡的選擇是令嵌入式操作系統(tǒng)設(shè)計(jì)者頭疼的事。一般的嵌入式操作系統(tǒng)都是兩種方案的高效結(jié)合,μC/OSII也不例外。除此之外,嵌入式操作系統(tǒng)對內(nèi)存的分配還有以下幾點(diǎn)要求:
?、?可靠性。內(nèi)存分配的請求必須得到滿足,如果分配失敗可能會(huì)帶來災(zāi)難性的后果。比如,航天飛機(jī)的嵌入式操作系統(tǒng)若發(fā)生內(nèi)存分配失效,損失是不可估量的。
② 快速性。嵌入式系統(tǒng)對實(shí)時(shí)性的保證,要求簡單、快速地分配內(nèi)存。
?、?高效性。嵌入式系統(tǒng)中內(nèi)存是一種有限、昂貴的資源,內(nèi)存分配要盡可能地減少浪費(fèi)。
μC/OSII作為一種典型的嵌入式操作系統(tǒng),其內(nèi)存管理同樣要滿足以上3點(diǎn)要求,下面簡單介紹μC/OSII的內(nèi)存管理策略,并分析其不足之處。
2 μC/OSII動(dòng)態(tài)內(nèi)存管理方案及不足
2.1 μC/OSII內(nèi)存管理方案簡介
μC/OSII內(nèi)存管理模塊主要由一個(gè)數(shù)據(jù)結(jié)構(gòu)體和5個(gè)函數(shù)組成:
◆ 內(nèi)存控制塊數(shù)據(jù)結(jié)構(gòu)OS_MEM;
◆ 內(nèi)存分區(qū)創(chuàng)建函數(shù)OSMemCreate(void *addr, INT32U nblks, INT32U blksize, INT8U *err);
◆ 內(nèi)存塊分配函數(shù)OSMemGet(OS_MEM *pmem , INT8U *err);
◆ 內(nèi)存塊釋放函數(shù)OSMemPut(OS_MEM *pmem , void *pblk);
◆ 內(nèi)存分區(qū)狀態(tài)查詢函數(shù)OSMemQuery(OS_MEM *pmem, OS_MEM_DATA *p_mem_data);
◆ 內(nèi)存控制塊鏈表初始化函數(shù)OSMemInit(void)。
μC/OSII用一個(gè)內(nèi)存控制塊(OS_MEM)來管理內(nèi)存分區(qū),主要通過以下4步來管理:
?、?內(nèi)存控制塊鏈表初始化函數(shù)OSMemInit()負(fù)責(zé)創(chuàng)建空內(nèi)存控制塊結(jié)構(gòu)的鏈表,鏈表長度由內(nèi)核OS_CFG.H文件中定義的OS_MAX_MEM_PART宏確定。
② 內(nèi)存塊創(chuàng)建函數(shù)OSMemCreate()先從空內(nèi)存控制塊結(jié)構(gòu)鏈表上獲取一個(gè)空的內(nèi)存控制根塊結(jié)構(gòu),根據(jù)用戶需要內(nèi)存塊的大小來創(chuàng)建分區(qū)。一個(gè)分區(qū)中含有相同大小的內(nèi)存塊,各內(nèi)存塊也是通過鏈表鏈接起來,而不同分區(qū)中的內(nèi)存塊大小一般不同,如圖1所示的PartitiON # 1和Partition # 2中內(nèi)存塊的大小是不同的。

圖1 μC/OSII通過內(nèi)存控制塊管理內(nèi)存
③ 內(nèi)存塊分配函數(shù)OSMemGet()通過從內(nèi)存控制塊鏈表中找到能夠滿足自己內(nèi)存塊需要的內(nèi)存控制塊,然后從這個(gè)內(nèi)存控制塊指向的分區(qū)鏈表首部得到自己需要的內(nèi)存塊。
?、?內(nèi)存塊釋放函數(shù)OSMemPut()負(fù)責(zé)回收內(nèi)存塊。當(dāng)應(yīng)用程序不再使用某一個(gè)內(nèi)存塊時(shí),必須及時(shí)把它釋放,并放回到相應(yīng)的內(nèi)存分區(qū)中。
2.2 μC/OSII內(nèi)存管理方案的不足之處
如前所述,μC/OSII的內(nèi)存管理方案簡短精煉,僅百余行代碼,5個(gè)函數(shù)就能勝任。然而考慮到第1節(jié)提到的嵌入式系統(tǒng)對內(nèi)存管理策略的3個(gè)要求,μC/OSII的內(nèi)存管理策略存在以下不足之處:
?、?原μC/OSII內(nèi)存管理方案可靠性不高。因?yàn)樵桨钢懈鲀?nèi)存分區(qū)之間是孤立的,沒有聯(lián)系。一個(gè)內(nèi)存分區(qū)上的內(nèi)存塊用完時(shí),不能利用其他分區(qū)上的內(nèi)存塊,而只是簡單地報(bào)錯(cuò),從而使系統(tǒng)可靠性大大降低。在內(nèi)存塊大小及需求量不確定的場合,如果經(jīng)常發(fā)生內(nèi)存申請得不到滿足的情況,是嵌入式系統(tǒng)所不能容忍的。
?、?原μC/OSII內(nèi)存管理方案中內(nèi)存分配不夠靈活。舉個(gè)例子來說,一個(gè)應(yīng)用程序需要大小為1 KB、512 B、256 B三種內(nèi)存塊,原方案有兩種解決方案,一是創(chuàng)建一個(gè)內(nèi)存塊大小為1 KB的內(nèi)存分區(qū),內(nèi)存塊數(shù)目至少為3個(gè);二是創(chuàng)建3個(gè)內(nèi)存分區(qū),內(nèi)存塊大小分別為1 KB、512 B、256 B。方案一創(chuàng)建了較少分區(qū),性能有保證,但造成內(nèi)存資源的浪費(fèi);方案二雖然沒有浪費(fèi)內(nèi)存,但卻調(diào)用3次OS_MemCreate()函數(shù),效率較低。
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- stm32 單片機(jī)的__attribute__ ((at())絕對定位及首次適應(yīng)算法的動(dòng)態(tài)內(nèi)存管理
- 【STM32H7教程】第27章 STM32H7的TCM,SRAM等五塊內(nèi)存的動(dòng)態(tài)內(nèi)存分配實(shí)現(xiàn)
- 關(guān)于stm32 MCU申請動(dòng)態(tài)內(nèi)存malloc的認(rèn)識
- EE-418:ADSP-2156x動(dòng)態(tài)內(nèi)存控制器電路板設(shè)計(jì)指南
- 伙伴算法如何才能在Linux內(nèi)核中實(shí)現(xiàn)應(yīng)用及其改進(jìn) 14次下載
- 51單片機(jī)如何使用動(dòng)態(tài)內(nèi)存
- 架空導(dǎo)線動(dòng)態(tài)載流量的分析及改進(jìn)算法 0次下載
- 基于μCOS-II的TLSF動(dòng)態(tài)內(nèi)存分配算法的應(yīng)用與仿真 44次下載
- LINUX源代碼分析-內(nèi)存管理 102次下載
- 基于Core的動(dòng)態(tài)內(nèi)存分配方案 38次下載
- 動(dòng)態(tài)內(nèi)存錯(cuò)誤的靜態(tài)檢測 53次下載
- 一種新的嵌入式實(shí)時(shí)動(dòng)態(tài)內(nèi)存管理結(jié)構(gòu)
- 一個(gè)動(dòng)態(tài)內(nèi)存管理模塊的實(shí)現(xiàn)
- 一個(gè)動(dòng)態(tài)內(nèi)存管理模塊的實(shí)現(xiàn)
- 通信設(shè)備中內(nèi)存管理優(yōu)化
- 你知道嗎? 51單片機(jī)也有動(dòng)態(tài)內(nèi)存分配 2.8k次閱讀
- 探索推理時(shí)KV Cache的動(dòng)態(tài)內(nèi)存壓縮方法 1.7k次閱讀
- C語言中的動(dòng)態(tài)內(nèi)存管理講解 932次閱讀
- 為什么需要動(dòng)態(tài)分配內(nèi)存? 3.9k次閱讀
- 使用MM32F3270基于Azure RTOS動(dòng)態(tài)內(nèi)存管理的應(yīng)用 1.8k次閱讀
- 基于智能狀態(tài)和源代碼插樁的C程序內(nèi)存安全性動(dòng)態(tài)分析 2.6k次閱讀
- 嵌入式開發(fā)是否應(yīng)該使用動(dòng)態(tài)內(nèi)存分配 2.2k次閱讀
- 嵌入式中需要用到動(dòng)態(tài)內(nèi)存嗎 3.5k次閱讀
- 干貨 | 嵌入式C語言的內(nèi)存管理 5.6k次閱讀
- C語言動(dòng)態(tài)內(nèi)存分配分析 4.7k次閱讀
- C語言中的動(dòng)態(tài)內(nèi)存管理 3.4k次閱讀
- 動(dòng)態(tài)內(nèi)存分配舉例,以及動(dòng)態(tài)數(shù)組的構(gòu)造 8k次閱讀
- 基于μC/OSII和ARM7 中斷機(jī)制的IRQ中斷響應(yīng)機(jī)制改進(jìn)及優(yōu)化解決方案 2.4k次閱讀
- 一種基于Buddy算法思想、高可靠性的內(nèi)存管理策略 2k次閱讀
- MicroBlaze:malloc 函數(shù)動(dòng)態(tài)分配內(nèi)存溢出 2.4k次閱讀
下載排行
本周
- 1冷柜-電氣控制系統(tǒng)講解
- 13.68 MB | 4次下載 | 10 積分
- 2安川A1000變頻器中文版說明書
- 20.16 MB | 3次下載 | 3 積分
- 3直流電路的組成和基本定律
- 1.67 MB | 2次下載 | 免費(fèi)
- 4丹佛斯2800系列變頻器說明書
- 8.00 MB | 1次下載 | 5 積分
- 5PC8011同步開關(guān)型降壓3.5A單節(jié)鋰電池充電管理電路技術(shù)手冊
- 0.74 MB | 1次下載 | 免費(fèi)
- 6ES7243E+ES8311音頻錄制與播放電路資料
- 0.06 MB | 1次下載 | 5 積分
- 7SDM02 激光測距模塊產(chǎn)品手冊
- 0.43 MB | 1次下載 | 免費(fèi)
- 8SDFM 激光測距模塊模組手冊
- 0.54 MB | 1次下載 | 免費(fèi)
本月
- 1CH341編程器軟件NeoProgrammer_2.2.0.10
- 20.47 MB | 170次下載 | 1 積分
- 22025智能家居傳感器市場分析及創(chuàng)新應(yīng)用
- 3.11 MB | 43次下載 | 免費(fèi)
- 3RV1126B系列開發(fā)板產(chǎn)品資料
- 4.19 MB | 18次下載 | 免費(fèi)
- 4CH341編程軟件下載
- 2.50 MB | 16次下載 | 5 積分
- 5全志系列-米爾基于T153核心板開發(fā)板 四核異構(gòu)、3路千兆網(wǎng),賦能多元化工業(yè)場景
- 3.05 MB | 12次下載 | 免費(fèi)
- 6【開源】60余套STM32單片機(jī)、嵌入式Linux、物聯(lián)網(wǎng)、人工智能項(xiàng)目案例及入門學(xué)習(xí)資源包
- 10.55 MB | 8次下載 | 免費(fèi)
- 7冷柜-電氣控制系統(tǒng)講解
- 13.68 MB | 4次下載 | 10 積分
- 8特斯拉MODEL S車載充電機(jī)主電路回路原理圖
- 0.81 MB | 4次下載 | 3 積分
總榜
- 1matlab軟件下載入口
- 未知 | 935137次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計(jì)
- 1.48MB | 420064次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233094次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191448次下載 | 10 積分
- 5十天學(xué)會(huì)AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183356次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81604次下載 | 10 積分
- 7Keil工具M(jìn)DK-Arm免費(fèi)下載
- 0.02 MB | 73824次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65991次下載 | 10 積分
電子發(fā)燒友App





創(chuàng)作
發(fā)文章
發(fā)帖
提問
發(fā)資料
發(fā)視頻
上傳資料賺積分
評論