基于μC/OS-Ⅱ應(yīng)用系統(tǒng)的任務(wù)劃分實例
μC/OS-Ⅱ是由Jean J.Labrosse于1992年開始提出的一個源碼公開的嵌入式實時多任務(wù)操作系統(tǒng),至今仍在繼續(xù)發(fā)展,其已經(jīng)在工業(yè)控制、儀器儀表、汽車電子、航空航天和消費電子等領(lǐng)域得到了廣泛應(yīng)用。它采用占先式實時調(diào)度方式,結(jié)構(gòu)簡潔精練、可讀性強、性能穩(wěn)定、便于移植,只需少量的工作就能將其移植到8位、16位和32位微處理器上。目前,μC/OS-Ⅱ已成為嵌入式開發(fā)人員入門嵌入式操作系統(tǒng)的合適選擇。
開發(fā)基于μC/OS-Ⅱ的嵌入式應(yīng)用系統(tǒng),首先需針對目標硬件平臺對μC/OS-Ⅱ進行移植。在詳細分析總體需求的基礎(chǔ)上,將系統(tǒng)功能合理地劃分為多個不同任務(wù)實現(xiàn)。由此可見,在實現(xiàn)嵌入式應(yīng)用系統(tǒng)的過程中,任務(wù)劃分是十分重要的環(huán)節(jié)。劃分任務(wù)是否合理有效不僅直接決定了μC/OS-Ⅱ的性能和執(zhí)行效率,還間接影響著應(yīng)用系統(tǒng)甚至整個項目的成敗。對于國內(nèi)眾多嵌入式方向的研究人員和愛好者,基于實時操作系統(tǒng)μC/OS-Ⅱ進行教學或者研發(fā),大多側(cè)重于μC/OS-Ⅱ在各種特定目標硬件平臺上的移植和簡單使用。而μC/OS-Ⅱ上的復雜系統(tǒng)開發(fā)特別是劃分任務(wù)策略雖已引起諸多關(guān)注,但到目前為止卻鮮有詳細而系統(tǒng)的研究成果。本文在總結(jié)前人工作和實際開發(fā)經(jīng)驗的基礎(chǔ)上,研究了μC/OS-Ⅱ任務(wù)劃分的方法和原則,并結(jié)合實踐給出基于MC9S12NE64硬件平臺的應(yīng)用實例。
1 μC/OS-Ⅱ的任務(wù)管理機制
在μC/OS-Ⅱ中,每個任務(wù)可以是一個典型的無限循環(huán),都處在μC/OS-Ⅱ規(guī)定的一種任務(wù)狀態(tài)。程序員把一個大地應(yīng)用程序分成相對獨立的多個任務(wù)來完成,大大提高了CPU的利用率,極大地方便了應(yīng)用程序的設(shè)計和維護。而多任務(wù)系統(tǒng)則通過任務(wù)切換實現(xiàn)各個任務(wù)之間的調(diào)度運行。
從存儲結(jié)構(gòu)來看,任務(wù)由3個部分組成:任務(wù)的程序代碼、任務(wù)堆棧和任務(wù)控制塊(PCB)。其中,任務(wù)堆棧用來保存該任務(wù)運行時的工作環(huán)境;任務(wù)控制塊用來保存該任務(wù)的一些屬性;任務(wù)程序代碼則描述了該任務(wù)的執(zhí)行過程。μC/OS-Ⅱ可以管理多達64個任務(wù),其中的空任務(wù)(IDLE)和統(tǒng)計任務(wù)(STATISTICS)為系統(tǒng)任務(wù),其余都屬于用戶任務(wù)。μC/OS-Ⅱ規(guī)定其每個任務(wù)必須設(shè)置為不同且惟一的優(yōu)先級(優(yōu)先級的數(shù)值越小,則代表任務(wù)的優(yōu)先級別越高),而μC/OS-Ⅱ內(nèi)核會調(diào)度處于就緒狀態(tài)優(yōu)先級最高的任務(wù)進行處理,并分配CPU。就緒狀態(tài)屬于任務(wù)的5種狀態(tài)之一,其余4種狀態(tài)分別為:睡眠狀態(tài)、運行狀態(tài)、等待狀態(tài)、中斷服務(wù)狀態(tài)。μC/OS-Ⅱ的任務(wù)總會處于這5種狀態(tài)之一,并根據(jù)不同的條件在5種狀態(tài)中進行切換,如圖1所示。
2 任務(wù)劃分的方法
2.1 以硬件模塊為對象劃分任務(wù)
在使用μC/OS-Ⅱ劃分任務(wù)時,應(yīng)將各硬件模塊相關(guān)的驅(qū)動程序劃分為不同的任務(wù),根據(jù)硬件模塊在系統(tǒng)功能中的關(guān)鍵性順序設(shè)定相應(yīng)的優(yōu)先級。以MCU為中心,將各硬件驅(qū)動程序劃分為獨立的任務(wù),不僅有效防止了爭用硬件模塊出現(xiàn)的問題,還能夠提高整個μC/OS-Ⅱ的執(zhí)行效率,滿足應(yīng)用系統(tǒng)的實時性要求,為系統(tǒng)維護和擴展功能打下良好的基礎(chǔ)。
將不同硬件模塊的操作劃分為不同的任務(wù),使得應(yīng)用系統(tǒng)必須通過μC/OS-Ⅱ內(nèi)核調(diào)度相應(yīng)的任務(wù),才能實現(xiàn)對于某個硬件模塊的訪問。這樣,每個模塊都有且只有惟一的任務(wù)與之對應(yīng),其他任務(wù)則無權(quán)時訪問它。這種操作模式有效地避免了由于多個任務(wù)同時爭用同一硬件模塊造成的沖突甚至死鎖現(xiàn)象。
按照硬件模塊劃分任務(wù),可以有效提高μC/OS-Ⅱ的工作效率,增強應(yīng)用系統(tǒng)對于實時要求的處理能力。例如:如果當前系統(tǒng)正在對并口設(shè)備進行處理,由于并口屬于慢速設(shè)備,其執(zhí)行速度遠遠落后于MCU總線頻率,因此在其工作過程中MCU大部分時間處于空閑狀態(tài),即無事可做直到并口處理完畢為止。將并口驅(qū)動獨立為單個任務(wù)之后,μC/OS-Ⅱ內(nèi)核就可以通過任務(wù)調(diào)度使并口處理任務(wù)和其他任務(wù)并發(fā)執(zhí)行,減少MCU處于空閑狀態(tài)的時間,從而提高了整個應(yīng)用系統(tǒng)運行效率。
硬件模塊與硬件驅(qū)動任務(wù)一一對應(yīng),使整個軟件系統(tǒng)框架清晰、結(jié)構(gòu)合理,增強了系統(tǒng)的可維護性和可擴展性。以增加串行通信功能為例,開發(fā)人員只要編寫相應(yīng)串口驅(qū)動程序,在μC/OS-Ⅱ中增加串行通信任務(wù)即可,無需修改任何其他模塊的任務(wù)代碼。
2.2 劃分強實時性任務(wù)
實時即立即、及時的意思,根據(jù)應(yīng)用中的實時要求,可以將其分為強實時和弱實時2大類。強實時對于響應(yīng)時間要求很高,如果實時性得不到滿足,系統(tǒng)會出現(xiàn)錯誤甚至難以挽回的故障。弱實時雖然同樣要求調(diào)度時間短,響應(yīng)速度快,但其確定性較差,超過限定時間也能勉強工作。在基于μC/OS-Ⅱ的嵌入式應(yīng)用系統(tǒng)中,強實時任務(wù)能夠在限定的時間范圍內(nèi)調(diào)度執(zhí)行,是整個系統(tǒng)穩(wěn)定可靠,實時有效的重要保障。因此,在劃分μC/OS-Ⅱ任務(wù)時,應(yīng)將每個強實時應(yīng)用劃分為獨立的任務(wù),與其他應(yīng)用分開,并設(shè)定高優(yōu)先級,以保證強實時事件的限時發(fā)生,避免出現(xiàn)災(zāi)難性后果。
假設(shè)把某一強實時應(yīng)用與一弱實時性要求的應(yīng)用一起打包成為1個任務(wù)。在嵌入式應(yīng)用系統(tǒng)運行過程中,一旦該弱實時應(yīng)用因為某種原因(例如:等待內(nèi)存數(shù)據(jù)、等待外部輸入信號、等待中斷發(fā)生等)導致整個任務(wù)進入等待狀態(tài),則在等待的事件發(fā)生之前,強實時應(yīng)用也無法通過任務(wù)調(diào)度得以執(zhí)行。在強實時系統(tǒng)中,出現(xiàn)了以上所述的情況,結(jié)果是不堪設(shè)想的。
如果強實時性應(yīng)用允許通過中斷方式“通知”μC/OS-Ⅱ內(nèi)核,則可將該強實時任務(wù)代碼放入相應(yīng)的中斷服務(wù)程序中去處理。在中斷服務(wù)程序在發(fā)生引起中斷處理的事件后,由硬件機制自動加載運行(把中斷服務(wù)程序的入口地址放入PC寄存器),無需軟件調(diào)度干涉,因此可更好保證應(yīng)用功能的強實時性。在中斷服務(wù)程序中執(zhí)行強實時性任務(wù)代碼,同樣必須遵循中斷服務(wù)程序要盡可能簡短的原則。具體的方法是通過分析每個強實時任務(wù)功能和代碼,將其最重要的核心部分放人中斷處理程序中,其余部分形成一個單獨的任務(wù),兩者可通過任務(wù)同步機制(信號量、消息郵箱或者消息隊列)進行聯(lián)系,以達到簡化中斷處理過程的目的。
2.3 分割耗時較多的任務(wù)
評論