嵌入式系統(tǒng)在航天,、軍事、工控以及家電等方面得到了廣泛應(yīng)用,。大量的嵌入式系統(tǒng)具有實(shí)時(shí)性的要求,,但是由于體積、能耗,、價(jià)格等方面的約束,,其處理器速度往往比較慢,存儲(chǔ)器容量也有限,。而傳統(tǒng)的實(shí)時(shí)操作系統(tǒng)難以簡單地移植到嵌入式系統(tǒng)中,,所以需要重新開發(fā)針對(duì)嵌入式系統(tǒng)特性的實(shí)時(shí)操作系統(tǒng)。任務(wù)調(diào)度策略是實(shí)時(shí)系統(tǒng)內(nèi)核的關(guān)鍵部分,,如何進(jìn)行任務(wù)調(diào)度,,使得各個(gè)任務(wù)能在其期限之內(nèi)得以完成,是實(shí)時(shí)操作系統(tǒng)的重要研究領(lǐng)域,。而不同的操作系統(tǒng)對(duì)任務(wù)調(diào)度的機(jī)制也有所不同,,本文對(duì)目前比較流行的操作系統(tǒng)——VxWorks,、μClinux、μC/OS-II,、Windows CE的任務(wù)切換機(jī)制進(jìn)行分析和比較,。
1 操作系統(tǒng)介紹
1.1 VxWorks
VxWorks是美國WindRiver公司的產(chǎn)品,是目前嵌入式系統(tǒng)領(lǐng)域中應(yīng)用很廣泛,、市場占有率比較高的嵌入式操作系統(tǒng)。VxWorks實(shí)時(shí)操作系統(tǒng)由400多個(gè)相對(duì)獨(dú)立,、短小精悍的目標(biāo)模塊組成,,用戶可根據(jù)需要選擇適當(dāng)?shù)哪K來裁剪和配置系統(tǒng);提供基于優(yōu)先級(jí)的任務(wù)調(diào)度,、任務(wù)間同步與通信,、中斷處理、定時(shí)器和內(nèi)存管理等功能,,內(nèi)建符合POSIX(可移植操作系統(tǒng)接口)規(guī)范的內(nèi)存管理,,以及多處理器控制程序;具有簡明易懂的用戶接口,,在核心方面甚至可以微縮到8KB,。
1.2 μC/OS-lI
μC/OS-II是在μC/OS的基礎(chǔ)上發(fā)展起來的,是美國嵌入式系統(tǒng)專家Jean J.Lal3rosse用C語言編寫的一個(gè)結(jié)構(gòu)小巧,、搶占式的多任務(wù)實(shí)時(shí)內(nèi)核,。μC/OS-II能管理64個(gè)任務(wù),并提供任務(wù)調(diào)度與管理,、內(nèi)存管理,、任務(wù)間同步與通信、時(shí)間管理和中斷服務(wù)等功能,,具有執(zhí)行效率高,、占用空間小、實(shí)時(shí)性能優(yōu)良和可擴(kuò)展性強(qiáng)等特點(diǎn),。
1.3 Linux
Linux是一種自由的Unix類多用戶,、多任務(wù)操作系統(tǒng),可運(yùn)行在Intel 80386及更高檔次的PC,、ARM,、DECAlpha等多種計(jì)算機(jī)平臺(tái)上,已經(jīng)成為應(yīng)用廣泛,、可靠性高,、功能強(qiáng)大的計(jì)算機(jī)操作系統(tǒng)。
1.4 WindOWS CE
微軟Windows CE是一個(gè)開放且多樣化的32位嵌入式操作系統(tǒng),。其設(shè)計(jì)目的是為符合廣泛的智能設(shè)備的需求,,例如從企業(yè)工具(如工業(yè)控制器,、通信集線器和收款機(jī)系統(tǒng))到電子消費(fèi)性產(chǎn)品(如攝影機(jī)、電話和家庭娛樂設(shè)備等),,提供自動(dòng)控制,、視聽娛樂、行動(dòng)計(jì)算,、終端機(jī)等各個(gè)應(yīng)用領(lǐng)域一個(gè)穩(wěn)定,、實(shí)時(shí)及多任務(wù)的操作系統(tǒng)。
2 任 務(wù)
2.1 任務(wù)切換概述
上下文切換(context switch),,其實(shí)際含義是任務(wù)切換,,或者CPU寄存器切換。當(dāng)多任務(wù)內(nèi)核決定運(yùn)行另外的任務(wù)時(shí),,它保存正在運(yùn)行任務(wù)的當(dāng)前狀態(tài),,也就是CPU寄存器中的全部內(nèi)容。這些內(nèi)容被保存在任務(wù)自己的堆棧中,,入棧工作完成后就把下一個(gè)將要運(yùn)行的任務(wù)的當(dāng)前狀況從該任務(wù)的棧中重新裝入CPU寄存器,,并開始下一個(gè)任務(wù)的運(yùn)行,這一過程就是context switch,。
每個(gè)任務(wù)都是整個(gè)應(yīng)用的一部分,,都被賦予一定的優(yōu)先級(jí),有自己的一套CPU寄存器和??臻g,,如圖1所示。
2.2 任務(wù)的切換與調(diào)度
μC/OS-II是可搶占實(shí)時(shí)多任務(wù)內(nèi)核,,它總是運(yùn)行優(yōu)先級(jí)最高的就緒任務(wù),,不支持時(shí)間片輪轉(zhuǎn)調(diào)度法,每個(gè)任務(wù)的優(yōu)先級(jí)要求不一樣,,且是唯一的,。它有5種狀態(tài),如圖2所示,。
當(dāng)一個(gè)任務(wù)在運(yùn)行狀態(tài)中時(shí),,如果沒有關(guān)閉中斷,就有可能被中斷打斷,,去執(zhí)行中斷服務(wù)子程序ISR,。執(zhí)行完后內(nèi)核要判斷此時(shí)是否有更高優(yōu)先級(jí),新的任務(wù)就緒,,如果有則原有的任務(wù)被搶占,,實(shí)現(xiàn)了任務(wù)的切換。
當(dāng)一個(gè)任務(wù)在運(yùn)行狀態(tài)中時(shí),,調(diào)用OSTimeDly()或OSTimeDlyHMSM()函數(shù),,該任務(wù)進(jìn)入等待狀態(tài),,一直到延時(shí)時(shí)間到,這2個(gè)函數(shù)立即強(qiáng)制執(zhí)行任務(wù)切換,,讓下一個(gè)優(yōu)先級(jí)最高的就緒任務(wù)運(yùn)行,。當(dāng)然,如果運(yùn)行的任務(wù)需要等待某一事件的發(fā)生,,可以調(diào)用一些函數(shù)(如OSFlag Pend(),、OSSemPend()、OSMutexPend(),、OSMboxPend(),、OSQPrnd()等)掛起該任務(wù),來實(shí)現(xiàn)任務(wù)的切換,。
實(shí)際的任務(wù)切換是調(diào)用OS_TASK_SW()函數(shù)。OS_TASK_SW()是一個(gè)宏,,是在μC/OS-II從低優(yōu)先級(jí)切換到高優(yōu)先級(jí)任務(wù)時(shí)須用到的,。OS_TA-SK_SW()總是在任務(wù)級(jí)代碼中被調(diào)用。另一個(gè)函數(shù)OSIntExit()用在中斷服務(wù)子程序ISR中,。當(dāng)中斷任務(wù)子程序使更高優(yōu)先級(jí)任務(wù)進(jìn)入就緒態(tài)時(shí),,OSintExit()完成任務(wù)切換功能,任務(wù)切換只是簡單地將處理器的寄存器保存到將被掛起的任務(wù)的堆棧中,,并且從堆棧中恢復(fù)要運(yùn)行的更高優(yōu)先級(jí)的任務(wù),。
μC/OS-II總是運(yùn)行進(jìn)入就緒態(tài)任務(wù)中優(yōu)先級(jí)最高的任務(wù),確定哪個(gè)任務(wù)優(yōu)先級(jí)最高,,以及下面該哪個(gè)任務(wù)運(yùn)行,。這一工作是由調(diào)度器完成的,所以任務(wù)調(diào)度的工作就是:查找準(zhǔn)備就緒的最高優(yōu)先級(jí)的任務(wù)并進(jìn)行上下文切換,。該工作由函數(shù)OSSched()完成,。中斷級(jí)的調(diào)度由OS-intExt()完成。代碼如下:
在Linux系統(tǒng)中,,任務(wù)的上下文切換和調(diào)度比較復(fù)雜,。Linux的上下文切換功能是由context_switch()函數(shù)完成的。代碼如下:
context_switch()完成了2個(gè)工作:
?、偾袚Q虛擬內(nèi)存映射,,即負(fù)責(zé)把虛擬內(nèi)存從被切換下來的進(jìn)程映射到新進(jìn)程中,該功能由函數(shù)switcn_mm()實(shí)現(xiàn),。
?、谇袚Q進(jìn)程的寄存器狀態(tài),即負(fù)責(zé)從一個(gè)進(jìn)程的處理器狀態(tài)切換到新進(jìn)程的處理器狀態(tài),,該功能由函數(shù)switcn_to()實(shí)現(xiàn),。
在多任務(wù)系統(tǒng)中,,都會(huì)提供一個(gè)系統(tǒng)函數(shù)來進(jìn)行進(jìn)程(任務(wù))間切換,綜合來說,,它們有兩種進(jìn)程(任務(wù))切換方式:
?、儆蛇M(jìn)程(任務(wù))本身直接調(diào)用任務(wù)切換函數(shù)進(jìn)行進(jìn)程(任務(wù))切換。在當(dāng)前進(jìn)程(任務(wù))因?yàn)椴荒塬@得必需的資源而立即被堵塞時(shí),,就由進(jìn)程(任務(wù))本身直接調(diào)用進(jìn)程(任務(wù))切換函數(shù)進(jìn)行進(jìn)程(任務(wù))間調(diào)度,。在Linux中可以直接調(diào)用schedule()函數(shù)來實(shí)現(xiàn)。
?、谘舆t調(diào)用任務(wù)切換函數(shù)進(jìn)行進(jìn)程(任務(wù))切換,。此方式是把當(dāng)前進(jìn)程(任務(wù))設(shè)置一調(diào)度標(biāo)志而以延遲方式調(diào)用任務(wù)切換函數(shù)進(jìn)行進(jìn)程(任務(wù))切換。在Linux系統(tǒng)中,,總是在恢復(fù)用戶態(tài)進(jìn)程執(zhí)行之前,,檢查這一調(diào)度標(biāo)志,在這里標(biāo)志是need_resched,,如果有這一標(biāo)志,,就調(diào)用調(diào)度函數(shù)進(jìn)行進(jìn)程切換。
此種情況主要包括以下幾種:
?、佼?dāng)前進(jìn)程用完了它的CPU時(shí)間片,,由scheduler_tick()函數(shù)完成schedule()的延遲調(diào)用。
?、诋?dāng)一個(gè)被喚醒進(jìn)程的優(yōu)先級(jí)比當(dāng)前進(jìn)程優(yōu)先級(jí)高時(shí),,由try_to_wake_up()函數(shù)完成schedule()的延遲調(diào)用。
?、郛?dāng)發(fā)出系統(tǒng)調(diào)用sched_setscheduler()時(shí),。在這些情況中,主要由于系統(tǒng)調(diào)用或中斷而進(jìn)入內(nèi)核態(tài),,或者當(dāng)前進(jìn)程本來在內(nèi)核態(tài)時(shí),,返回用戶態(tài)時(shí)發(fā)生的。
在VxWorks系統(tǒng)中,,任務(wù)的優(yōu)先級(jí)為0~255,。任務(wù)有4種狀態(tài):就緒態(tài)、懸置態(tài),、休眠態(tài)和延遲態(tài),,如圖3所示。
內(nèi)核缺省調(diào)度機(jī)制為基于優(yōu)先級(jí)的搶占式調(diào)度,。采用這種機(jī)制,,系統(tǒng)把處理機(jī)分配給優(yōu)先級(jí)最高的進(jìn)程,使之執(zhí)行,。一旦出現(xiàn)優(yōu)先級(jí)更高的進(jìn)程時(shí),,該任務(wù)被剝奪CPU使用權(quán),,而去執(zhí)行優(yōu)先級(jí)更高的任務(wù)。而在相同優(yōu)先級(jí)的多個(gè)任務(wù)之間,,采用時(shí)間片輪轉(zhuǎn)調(diào)度機(jī)制,。采用這種機(jī)制,當(dāng)一個(gè)任務(wù)到達(dá)時(shí),,它被安排在輪轉(zhuǎn)隊(duì)列的后面,,等待分配給自己的時(shí)間片的到來,如果在時(shí)間片內(nèi)沒有結(jié)束,,則在等待屬于自己的時(shí)間片的到來,,直到任務(wù)完成。
在VxWorks系統(tǒng)中,,對(duì)于優(yōu)先級(jí)相同的任務(wù),,如果狀態(tài)為Ready,則可以通過時(shí)間片輪轉(zhuǎn)方式公平享有CPU資源,。輪轉(zhuǎn)調(diào)度法給處于就緒態(tài)的每個(gè)同優(yōu)先級(jí)的任務(wù)分配一個(gè)相同的時(shí)間片,,該時(shí)間片的大小由系統(tǒng)調(diào)用KernelTimeSlice決定。
在Windows CE系統(tǒng)中,,Windows CE 3.0之后,系統(tǒng)支持的優(yōu)先級(jí)增長到256個(gè),,0優(yōu)先級(jí)級(jí)別最高,,255優(yōu)先級(jí)級(jí)別最低。0~247的優(yōu)先級(jí)屬于實(shí)時(shí)性優(yōu)先級(jí),,248~255的優(yōu)先級(jí)一般分配給普通應(yīng)用程序,。Windows CE.NET采用基于動(dòng)態(tài)優(yōu)先級(jí)的搶占式多任務(wù)機(jī)制,越重要的任務(wù),,優(yōu)先級(jí)越高,。Windows CE.NET在任務(wù)調(diào)度中采用任務(wù)優(yōu)先級(jí)制、優(yōu)先級(jí)動(dòng)態(tài)調(diào)整機(jī)制和搶占式調(diào)度,,都是為了最大限度地滿足系統(tǒng)的實(shí)時(shí)性要求,。對(duì)于一個(gè)優(yōu)先級(jí)只有一個(gè)任務(wù)的簡單系統(tǒng)內(nèi)核,上述的3種調(diào)度足以滿足要求,,但對(duì)于Windows CE.NET這樣復(fù)雜,、高性能的多任務(wù)實(shí)時(shí)內(nèi)核,由于多個(gè)任務(wù)允許公用一個(gè)優(yōu)先級(jí),,則相同優(yōu)先級(jí)的任務(wù)要采用Windows CE.NET提供的時(shí)間片輪轉(zhuǎn)法實(shí)現(xiàn),。具體實(shí)現(xiàn)如圖4所示。
在沒有更高優(yōu)先級(jí)任務(wù)就緒時(shí),,相同優(yōu)先級(jí)的任務(wù)依照就緒的先后次序執(zhí)行,。執(zhí)行一定的時(shí)間片后,,無論任務(wù)完成與否,均轉(zhuǎn)入下一任務(wù)運(yùn)行,。未運(yùn)行完的任務(wù)釋放處理器的控制權(quán)后轉(zhuǎn)入就緒隊(duì)列的末尾,,依次往復(fù)。這樣的輪轉(zhuǎn)策略保證了具有相同優(yōu)先級(jí)的任務(wù)平等地享有控制權(quán)的處理權(quán),。在Windows CE系統(tǒng)中,,一般設(shè)置的時(shí)間片大小為10 ms。
3 總結(jié)
本文對(duì)幾種操作系統(tǒng)的內(nèi)核的主要部分(任務(wù)切換與調(diào)度)進(jìn)行了分析比較,,便于理解其實(shí)時(shí)性,、可靠性等方面的優(yōu)缺點(diǎn),為以后進(jìn)行系統(tǒng)的移植和開發(fā)打下基礎(chǔ),。由于筆者時(shí)間和精力有限,,而且目前的操作系統(tǒng)很多,本文只分析了4種系統(tǒng),,還不夠完善,。未來可以對(duì)其他更多的實(shí)時(shí)操作系統(tǒng)進(jìn)行分析比較。