嵌入式系統(tǒng)通用的應(yīng)用軟件結(jié)構(gòu)研究
出處:維庫(kù)電子市場(chǎng)網(wǎng) 發(fā)布于:2023-07-21 16:50:17
摘要:嵌入式實(shí)時(shí)多任務(wù)操作系統(tǒng)在軟件編程上有一定的相似性。這種相似的特性,使得我們可以將個(gè)別系統(tǒng)的編程經(jīng)驗(yàn)推廣到更多的系統(tǒng)上。本文就μC/OS-II內(nèi)核的任務(wù)管理和內(nèi)存管理進(jìn)行基本的介紹,并介紹一個(gè)通用的應(yīng)用軟件結(jié)構(gòu)。然后,與之相對(duì)應(yīng),提供兩個(gè)不同操作系統(tǒng)下的應(yīng)用實(shí)例。
引言
嵌入式系統(tǒng)的面向應(yīng)用特性,使得大多數(shù)程序員沉陷于不同的應(yīng)用中。在進(jìn)入新的一輪開發(fā)后,往往只有一些簡(jiǎn)單的經(jīng)驗(yàn)可供參考。為了加快應(yīng)用的開發(fā)進(jìn)度,有必要研究一種統(tǒng)一的應(yīng)用軟件結(jié)構(gòu),使開發(fā)人員能夠通過(guò)簡(jiǎn)單模式套用,簡(jiǎn)化大量系統(tǒng)研究方面的工作,以加快嵌入式開發(fā)人員對(duì)新系統(tǒng)的理解和使用。
操作系統(tǒng)μC/OS-II和ECOS(Embedded Configurable OS)是我在研發(fā)過(guò)程中使用過(guò)的兩個(gè)系統(tǒng)。這兩個(gè)源碼公開的系統(tǒng)是我們研究的基礎(chǔ)。開發(fā)平臺(tái)依次是PC機(jī)和EP7212開發(fā)板。
1 μC/OS-II內(nèi)核
對(duì)于一個(gè)嵌入式系統(tǒng)內(nèi)核,我們關(guān)心的是:任務(wù)調(diào)度、內(nèi)存管理及時(shí)間特性等。這里,只介紹與多任務(wù)編程聯(lián)系多的任務(wù)調(diào)度和內(nèi)存管理。
1.1 任務(wù)調(diào)度
任務(wù)的狀態(tài)有休眠、就緒及運(yùn)行幾種。任務(wù)調(diào)度就是遵循一定的原則,使多個(gè)任務(wù)共同使用同一處理機(jī)的過(guò)程。這一過(guò)程主要是通過(guò)對(duì)任務(wù)控制塊(TCB)的管理來(lái)實(shí)現(xiàn)的。
當(dāng)一個(gè)任務(wù)建立時(shí),μC/OS-II系統(tǒng)為其所對(duì)應(yīng)的OS_TCB賦值;當(dāng)任務(wù)的CPU使用權(quán)被剝奪時(shí),系統(tǒng)用OS_TCB來(lái)保存該任務(wù)的狀態(tài);當(dāng)任務(wù)重新得到CPU使用權(quán)時(shí),系統(tǒng)就可通過(guò)任務(wù)控制埠來(lái)使任務(wù)從被中斷處繼續(xù)執(zhí)行下去。
在μC/OS-II中,TCB內(nèi)包含如下基本項(xiàng):
*OSTCBStkPtr是一個(gè)指向當(dāng)前任務(wù)棧頂?shù)闹羔槪ㄟ^(guò)允許每個(gè)任務(wù)擁有自己的棧來(lái)減小系統(tǒng)的內(nèi)存開銷;
*OSTCBNextOSTCBPrev用于任務(wù)控制塊的雙重鏈接;
*OSTCBDly用于任務(wù)延時(shí)或超時(shí)限制;
*OSTCBStat任務(wù)的狀態(tài)字,0表示就緒態(tài);
*OSTCBPrio任務(wù)的優(yōu)先級(jí),值越小,優(yōu)先級(jí)越高。
在μC/OS-II中,還有兩個(gè)與任務(wù)調(diào)度相關(guān)的結(jié)構(gòu)就緒表和估級(jí)判定表。就緒表中有兩個(gè)變量用來(lái)存放每個(gè)任務(wù)的就緒標(biāo)志。通過(guò)分組與優(yōu)先級(jí)表中的項(xiàng)實(shí)現(xiàn)一一對(duì)應(yīng),進(jìn)而確定進(jìn)入就緒態(tài)的優(yōu)先級(jí)的任務(wù)。
任務(wù)調(diào)度算法原型:
*關(guān)中斷;
*取優(yōu)先級(jí)的就緒任務(wù);
*若不是當(dāng)前任務(wù),則進(jìn)行任務(wù)切換;
*開中斷。
任務(wù)切換中兩步完成:將被掛起的任務(wù)的微處理器寄存器堆入棧,然后,將較高優(yōu)先級(jí)的任務(wù)的寄存器值從棧中恢復(fù)到寄存器中。
1.2 內(nèi)存管理
在嵌入式系統(tǒng)中,為了更高效地使用內(nèi)存,除了常規(guī)的malloc()和free()外,通常提供不同的內(nèi)存組織形式,以滿足特殊應(yīng)用的需求。ΜC/OS-II中,操作系統(tǒng)把連續(xù)的大塊內(nèi)存按分區(qū)來(lái)管理,每個(gè)分區(qū)中包含整數(shù)大小相同的內(nèi)存塊。利用這種機(jī)制,μC/OS-II對(duì)malloc()和free()進(jìn)行改造,使得它們可分配和釋放固定大小的內(nèi)存塊,并且使這兩個(gè)函數(shù)的執(zhí)行時(shí)間也固定下來(lái)。
為了使用戶能得到需大小的內(nèi)存塊,在一個(gè)系統(tǒng)中可以多個(gè)內(nèi)存分區(qū),應(yīng)用程序可以從不同的內(nèi)存分區(qū)中取得不同大小的內(nèi)存塊。要注意的是,不同的內(nèi)存塊在釋放時(shí)必須重新放回它以前所屬的內(nèi)存分區(qū)。采用上述的內(nèi)存管理算法,解決了內(nèi)存碎片的問(wèn)題。
為了跟蹤每一個(gè)內(nèi)存分區(qū),μC/OS-II使用了內(nèi)存控制塊的數(shù)據(jù)結(jié)構(gòu),主要有:
OSMemAddr—指向內(nèi)存分區(qū)起始地址的指針;
OSMemFreeList—指向下一個(gè)空閑控制塊或下一個(gè)空閑內(nèi)存塊的指針;
OSMemBlkSize—內(nèi)存分區(qū)中內(nèi)存塊的大小,是用戶建立該內(nèi)存分區(qū)時(shí)指定的;
OSMemB1ks—內(nèi)存分區(qū)中總的內(nèi)存塊數(shù)量,是用戶建立該內(nèi)存分區(qū)時(shí)指定的;
OSMemNFree—內(nèi)存分區(qū)中當(dāng)前可以得到的空閑內(nèi)存塊數(shù)量。
在μC/OS-II中,也可以使用常規(guī)的malloc()和free()內(nèi)存管理函數(shù)來(lái)增強(qiáng)其可移植性,但在使用更嚴(yán)格的場(chǎng)合,應(yīng)使用系統(tǒng)提供的特殊的內(nèi)存管理。
2 應(yīng)用軟件
2.1 應(yīng)用軟件原型
對(duì)于8051單片機(jī)系統(tǒng)的編程,基本的架構(gòu)是一個(gè)無(wú)限循環(huán),應(yīng)用的所有事情基本上都是在這個(gè)超循環(huán)中實(shí)現(xiàn)的。在這種系統(tǒng)中,系統(tǒng)上只有一個(gè)任務(wù)在運(yùn)行,應(yīng)用就是整個(gè)系統(tǒng),而整個(gè)系統(tǒng)就是一個(gè)應(yīng)用。
與這種簡(jiǎn)單系統(tǒng)相似,超循環(huán)結(jié)構(gòu)在復(fù)雜的實(shí)時(shí)操作系統(tǒng)μC/OS-II中也是一個(gè)基本結(jié)構(gòu);但不再是系統(tǒng)級(jí)的,而只是任務(wù)級(jí)的。
在一個(gè)應(yīng)用中,至少有一個(gè)這樣的任務(wù),它包含這樣一個(gè)超循環(huán),以使其擁有與應(yīng)用相同的生存期,并由它完成應(yīng)用的全部或部分功能。
2.2 基本應(yīng)用軟件結(jié)構(gòu)
應(yīng)用軟件結(jié)構(gòu)存在不同性,是由應(yīng)用本身決定的;但作為基本結(jié)構(gòu),則是相似甚至是相同的。因?yàn)閷?duì)于不同的系統(tǒng),所調(diào)用的函數(shù)是不同的。下面給出基本應(yīng)用軟件結(jié)構(gòu)的文字描述。
①聲明系統(tǒng)的包含文件。
②聲明全局?jǐn)?shù)據(jù):任務(wù)數(shù)、任務(wù)的??臻g等。
③主函數(shù):
*系統(tǒng)初始化;
*創(chuàng)建主任務(wù);
*啟動(dòng)多任務(wù)執(zhí)行。
④主任務(wù):
*主任務(wù)初始化;
*若必要,可創(chuàng)立多個(gè)子任務(wù);
*進(jìn)入超循環(huán)或退出主任務(wù)。
⑤子任務(wù):
*子任務(wù)初始化;
*進(jìn)入超循環(huán)或退出子任務(wù)。
2.3 應(yīng)用軟件實(shí)例
(1)樣例1
為了簡(jiǎn)要說(shuō)明軟件結(jié)構(gòu)思想,我們?cè)赑C平臺(tái)、Windows 98系統(tǒng)下,采用了Borland公司的C++命令行編譯環(huán)境,說(shuō)明我們的應(yīng)用。
其中文件的主要功能,就是顯示一個(gè)HelloμC/OS-II embedded world!字符串。由于其是在μC/OS-II下實(shí)現(xiàn)的,與原理有相通性,這里就不再更多介紹了。
(2)樣例2
使用Cirrus Logic公司的開發(fā)板EP7212,運(yùn)行的操作系統(tǒng)是RedHat公司的ECOS。本應(yīng)用的主要功能是,把從串口2接收到的數(shù)據(jù)再發(fā)送回去,并且在初始化時(shí)加發(fā)一個(gè)“Hello eCos World!”字符串。
ECOS是一個(gè)比μC/OS-II更復(fù)雜的系統(tǒng),其支持的軟件結(jié)構(gòu)更豐富,但其對(duì)我們所抽象的軟件結(jié)構(gòu)依然支持得很好;只是在我們應(yīng)用的主函數(shù)中,已更好地將系統(tǒng)的初始化部分隱藏了起來(lái)。
版權(quán)與免責(zé)聲明
凡本網(wǎng)注明“出處:維庫(kù)電子市場(chǎng)網(wǎng)”的所有作品,版權(quán)均屬于維庫(kù)電子市場(chǎng)網(wǎng),轉(zhuǎn)載請(qǐng)必須注明維庫(kù)電子市場(chǎng)網(wǎng),http://www.hbjingang.com,違反者本網(wǎng)將追究相關(guān)法律責(zé)任。
本網(wǎng)轉(zhuǎn)載并注明自其它出處的作品,目的在于傳遞更多信息,并不代表本網(wǎng)贊同其觀點(diǎn)或證實(shí)其內(nèi)容的真實(shí)性,不承擔(dān)此類作品侵權(quán)行為的直接責(zé)任及連帶責(zé)任。其他媒體、網(wǎng)站或個(gè)人從本網(wǎng)轉(zhuǎn)載時(shí),必須保留本網(wǎng)注明的作品出處,并自負(fù)版權(quán)等法律責(zé)任。
如涉及作品內(nèi)容、版權(quán)等問(wèn)題,請(qǐng)?jiān)谧髌钒l(fā)表之日起一周內(nèi)與本網(wǎng)聯(lián)系,否則視為放棄相關(guān)權(quán)利。
- ARM技術(shù)架構(gòu)與應(yīng)用開發(fā)實(shí)踐指南2026/1/6 10:40:19
- 嵌入式實(shí)時(shí)操作系統(tǒng)(RTOS)選型與移植技術(shù)指南2025/12/31 10:42:31
- 工業(yè)嵌入式系統(tǒng):通信接口技術(shù)選型與抗干擾設(shè)計(jì)實(shí)踐2025/12/15 14:36:53
- 深入解析嵌入式 OPENAMP 框架:開啟異核通信新時(shí)代2025/7/22 16:27:29
- 一文快速了解OPENWRT基礎(chǔ)知識(shí)2025/7/14 16:59:04
- PCB焊盤與過(guò)孔設(shè)計(jì)核心實(shí)操規(guī)范(含可焊性與可靠性保障)
- 汽車電子常用電子元器件選型指南
- MOSFET驅(qū)動(dòng)與隔離方案設(shè)計(jì)
- 高溫環(huán)境下電源IC選型建議
- 安防監(jiān)控設(shè)備連接器應(yīng)用分析
- 高速PCB信號(hào)完整性(SI)設(shè)計(jì)核心實(shí)操規(guī)范
- 鎖相環(huán)(PLL)中的環(huán)路濾波器:參數(shù)計(jì)算與穩(wěn)定性分析
- MOSFET反向恢復(fù)特性對(duì)系統(tǒng)的影響
- 電源IC在惡劣環(huán)境中的防護(hù)設(shè)計(jì)
- 連接器耐腐蝕性能測(cè)試方法









