資料介紹
1. 實時系統(tǒng)內(nèi)存分配
實時系統(tǒng)分為硬實時系統(tǒng)和軟實時系統(tǒng)。硬實時系統(tǒng)是指系統(tǒng)中各任務(wù)不僅要執(zhí)行無誤而且要做到準(zhǔn)時;軟實時系統(tǒng)是指系統(tǒng)中各任務(wù)運行的越快越好,并不要求限定某一任務(wù)必須在多長時間內(nèi)完成。
可以看出動態(tài)內(nèi)存分配是絕對不能用于硬實時系統(tǒng)的,因為動態(tài)分配具有時間不確定性(分配時間與內(nèi)存塊數(shù)量有關(guān)),而且動態(tài)分配可能產(chǎn)生分配不成功的情況。所以對于硬實時系統(tǒng),只能采用靜態(tài)內(nèi)存分配方式。靜態(tài)分配是指在編譯或鏈接時將程序所需的內(nèi)存空間分配好,這樣不會出現(xiàn)分配失敗的情況。
其實對于大多數(shù)實時系統(tǒng)而言,內(nèi)存分配都是采用兩種方式的結(jié)合,即動靜結(jié)合的分配方式。
2. 動靜結(jié)合內(nèi)存分配的一種實現(xiàn)
對于整個內(nèi)存,把它分為4個部分,即中斷向量區(qū)、系統(tǒng)映射區(qū)、系統(tǒng)內(nèi)存區(qū)和用戶內(nèi)存區(qū)。如圖1所示。
其中中斷向量表和系統(tǒng)映射區(qū)在編譯時已經(jīng)設(shè)定好,即采用靜態(tài)分區(qū)的方式。剩下的兩個部分可以按用戶要求配置。
2.1 系統(tǒng)內(nèi)存區(qū)分區(qū)
對于整個系統(tǒng)內(nèi)存區(qū),還需要要進行分區(qū)操作,使它產(chǎn)生多個分區(qū),每個分區(qū)中內(nèi)存塊的大小相等,各個分區(qū)之間內(nèi)存塊大小不等。這樣來滿足多種內(nèi)存申請需求。
2.1.1 系統(tǒng)分區(qū)類結(jié)構(gòu)定義
系統(tǒng)建立了一個內(nèi)存塊結(jié)構(gòu),它由一個指向下一個內(nèi)存塊的指針構(gòu)成,因為系統(tǒng)使用單向鏈表來管理空閑內(nèi)存塊,所以必須用每個內(nèi)存塊的這個指針來讓所有的空閑內(nèi)存塊連成一個鏈表。

圖1 內(nèi)存劃分示意圖
結(jié)構(gòu)如下:
struct memblock
{
void * next;
};
對于內(nèi)存分區(qū),采用面向?qū)ο蟮姆绞?,這樣減少了全局變量的使用,同時提高了可操作性。系統(tǒng)建立了內(nèi)存分區(qū)類結(jié)構(gòu)。它包含了該分區(qū)的信號量、內(nèi)存區(qū)的起始地址、內(nèi)存塊大小、內(nèi)存塊數(shù)量、空閑內(nèi)存塊數(shù)量、空閑內(nèi)存塊鏈表和鏈表尾部等。類結(jié)構(gòu)定義如下:
class mempartition
{
private:
semphore s; //控制該內(nèi)存分區(qū)的信號量
public:
long *start; //塊起始位置
void *freeulist; //空閑內(nèi)存塊鏈表
void *tail; //空閑內(nèi)存塊鏈表尾部
int unitsize; //內(nèi)存塊大小
short unitnum; //內(nèi)存塊數(shù)量
short freeunum; //空閑內(nèi)存塊數(shù)量
mempartition(); //初始化鏈表、信號量
void *GetUnit(); //獲取內(nèi)存塊
void PutUnit(void *); //釋放內(nèi)存塊
};
因為每個內(nèi)存分區(qū)都是多任務(wù)共享的,每次只能有一個任務(wù)或中斷服務(wù)程序進入該內(nèi)存分區(qū),所以需要設(shè)置信號量來管理它,當(dāng)然也可以采用關(guān)中斷的方式,關(guān)中斷可能導(dǎo)致中斷響應(yīng)延遲等問題,所以沒有采用這種方式。
實時系統(tǒng)分為硬實時系統(tǒng)和軟實時系統(tǒng)。硬實時系統(tǒng)是指系統(tǒng)中各任務(wù)不僅要執(zhí)行無誤而且要做到準(zhǔn)時;軟實時系統(tǒng)是指系統(tǒng)中各任務(wù)運行的越快越好,并不要求限定某一任務(wù)必須在多長時間內(nèi)完成。
可以看出動態(tài)內(nèi)存分配是絕對不能用于硬實時系統(tǒng)的,因為動態(tài)分配具有時間不確定性(分配時間與內(nèi)存塊數(shù)量有關(guān)),而且動態(tài)分配可能產(chǎn)生分配不成功的情況。所以對于硬實時系統(tǒng),只能采用靜態(tài)內(nèi)存分配方式。靜態(tài)分配是指在編譯或鏈接時將程序所需的內(nèi)存空間分配好,這樣不會出現(xiàn)分配失敗的情況。
其實對于大多數(shù)實時系統(tǒng)而言,內(nèi)存分配都是采用兩種方式的結(jié)合,即動靜結(jié)合的分配方式。
2. 動靜結(jié)合內(nèi)存分配的一種實現(xiàn)
對于整個內(nèi)存,把它分為4個部分,即中斷向量區(qū)、系統(tǒng)映射區(qū)、系統(tǒng)內(nèi)存區(qū)和用戶內(nèi)存區(qū)。如圖1所示。
其中中斷向量表和系統(tǒng)映射區(qū)在編譯時已經(jīng)設(shè)定好,即采用靜態(tài)分區(qū)的方式。剩下的兩個部分可以按用戶要求配置。
2.1 系統(tǒng)內(nèi)存區(qū)分區(qū)
對于整個系統(tǒng)內(nèi)存區(qū),還需要要進行分區(qū)操作,使它產(chǎn)生多個分區(qū),每個分區(qū)中內(nèi)存塊的大小相等,各個分區(qū)之間內(nèi)存塊大小不等。這樣來滿足多種內(nèi)存申請需求。
2.1.1 系統(tǒng)分區(qū)類結(jié)構(gòu)定義
系統(tǒng)建立了一個內(nèi)存塊結(jié)構(gòu),它由一個指向下一個內(nèi)存塊的指針構(gòu)成,因為系統(tǒng)使用單向鏈表來管理空閑內(nèi)存塊,所以必須用每個內(nèi)存塊的這個指針來讓所有的空閑內(nèi)存塊連成一個鏈表。

圖1 內(nèi)存劃分示意圖
結(jié)構(gòu)如下:
struct memblock
{
void * next;
};
對于內(nèi)存分區(qū),采用面向?qū)ο蟮姆绞?,這樣減少了全局變量的使用,同時提高了可操作性。系統(tǒng)建立了內(nèi)存分區(qū)類結(jié)構(gòu)。它包含了該分區(qū)的信號量、內(nèi)存區(qū)的起始地址、內(nèi)存塊大小、內(nèi)存塊數(shù)量、空閑內(nèi)存塊數(shù)量、空閑內(nèi)存塊鏈表和鏈表尾部等。類結(jié)構(gòu)定義如下:
class mempartition
{
private:
semphore s; //控制該內(nèi)存分區(qū)的信號量
public:
long *start; //塊起始位置
void *freeulist; //空閑內(nèi)存塊鏈表
void *tail; //空閑內(nèi)存塊鏈表尾部
int unitsize; //內(nèi)存塊大小
short unitnum; //內(nèi)存塊數(shù)量
short freeunum; //空閑內(nèi)存塊數(shù)量
mempartition(); //初始化鏈表、信號量
void *GetUnit(); //獲取內(nèi)存塊
void PutUnit(void *); //釋放內(nèi)存塊
};
因為每個內(nèi)存分區(qū)都是多任務(wù)共享的,每次只能有一個任務(wù)或中斷服務(wù)程序進入該內(nèi)存分區(qū),所以需要設(shè)置信號量來管理它,當(dāng)然也可以采用關(guān)中斷的方式,關(guān)中斷可能導(dǎo)致中斷響應(yīng)延遲等問題,所以沒有采用這種方式。
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- STM32內(nèi)存管理
- 嵌入式 Linux 中的內(nèi)存管理
- 鴻蒙內(nèi)核源碼分析: 虛擬內(nèi)存和物理內(nèi)存是怎么管理的 19次下載
- RTOS低功耗設(shè)計原理的講解和實現(xiàn)概述 22次下載
- TI-RTOS 2.00 用戶指南 24次下載
- 一種動靜結(jié)合的惡意程序函數(shù)調(diào)用圖提取方法 0次下載
- 動靜態(tài)相結(jié)合LED顯示【C語言版】 0次下載
- STM32上RTOS的中斷管理 0次下載
- 實時系統(tǒng)中動靜結(jié)合的內(nèi)存管理實現(xiàn)
- 全系統(tǒng)模擬中內(nèi)存管理單元的模擬實現(xiàn)
- 實時系統(tǒng)中動靜結(jié)合的內(nèi)存管理實現(xiàn)
- 可生存嵌入式OS內(nèi)存管理設(shè)計與實現(xiàn)
- 一個動態(tài)內(nèi)存管理模塊的實現(xiàn)
- 一個動態(tài)內(nèi)存管理模塊的實現(xiàn)
- 通信設(shè)備中內(nèi)存管理優(yōu)化
- Linux內(nèi)存管理中HVO的實現(xiàn)原理 271次閱讀
- 內(nèi)存管理的硬件結(jié)構(gòu) 359次閱讀
- RTOS的特性和類型 640次閱讀
- 深入理解Java 8內(nèi)存管理機制及故障排查實戰(zhàn)指南 1030次閱讀
- MMU內(nèi)存管理單元的工作原理和作用 2495次閱讀
- JVM內(nèi)存布局詳解 547次閱讀
- 使用MM32F3270基于Azure RTOS定時器組的應(yīng)用 1751次閱讀
- 使用MM32F3270基于Azure RTOS動態(tài)內(nèi)存管理的應(yīng)用 991次閱讀
- 使用MM32F3270基于Azure RTOS信號量的應(yīng)用 1071次閱讀
- RTOS多線程必須要MMU才行? 2478次閱讀
- Linux內(nèi)存管理體系介紹 1670次閱讀
- RTOS如何實現(xiàn)多任務(wù)?這篇文章告訴你答案 3508次閱讀
- 嵌入式系統(tǒng)內(nèi)存管理機制詳解 4552次閱讀
- 一文讀懂 Spark 內(nèi)存管理 974次閱讀
- LWIP內(nèi)存管理知識匯總 6951次閱讀
下載排行
本周
- 1TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費
- 2開關(guān)電源基礎(chǔ)知識
- 5.73 MB | 6次下載 | 免費
- 3100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 4嵌入式linux-聊天程序設(shè)計
- 0.60 MB | 3次下載 | 免費
- 5基于FPGA的光纖通信系統(tǒng)的設(shè)計與實現(xiàn)
- 0.61 MB | 2次下載 | 免費
- 6基于FPGA的C8051F單片機開發(fā)板設(shè)計
- 0.70 MB | 2次下載 | 免費
- 751單片機窗簾控制器仿真程序
- 1.93 MB | 2次下載 | 免費
- 8基于51單片機的RGB調(diào)色燈程序仿真
- 0.86 MB | 2次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 2555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33564次下載 | 免費
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費
- 4開關(guān)電源設(shè)計實例指南
- 未知 | 21548次下載 | 免費
- 5電氣工程師手冊免費下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費
- 6數(shù)字電路基礎(chǔ)pdf(下載)
- 未知 | 13750次下載 | 免費
- 7電子制作實例集錦 下載
- 未知 | 8113次下載 | 免費
- 8《LED驅(qū)動電路設(shè)計》 溫德爾著
- 0.00 MB | 6653次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537796次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191185次下載 | 免費
- 7十天學(xué)會AVR單片機與C語言視頻教程 下載
- 158M | 183278次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138040次下載 | 免費
評論