日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > 嵌入式 > 嵌入式軟件
[導(dǎo)讀]μC/OS-ll中任務(wù)調(diào)度算法的改進(jìn)

  要:介紹μCOSII嵌入式實(shí)時(shí)操作系統(tǒng)的特點(diǎn),分析單一的基于優(yōu)先級(jí)調(diào)度算法存在的不足。根據(jù)嵌入式應(yīng)用不同的實(shí)時(shí)性要求,將應(yīng)用劃分為實(shí)時(shí)任務(wù)、分時(shí)任務(wù)和后臺(tái)任務(wù)三種類型。針對(duì)分時(shí)任務(wù),新增加時(shí)間片調(diào)度算法,給出調(diào)度算法的實(shí)現(xiàn)方法,同時(shí)增加任務(wù)創(chuàng)建和銷毀的接口;降低基于μCOS1I操作系統(tǒng)的嵌入式產(chǎn)品開(kāi)發(fā)難度和設(shè)計(jì)成本,有利于該操作系統(tǒng)的應(yīng)用推廣。

關(guān)鍵詞:μCOSII  嵌入式系統(tǒng)  任務(wù)調(diào)度算法  時(shí)間片調(diào)度

 

 

    目前,操作系統(tǒng)內(nèi)核的軟件中,μC0S-II稱得上是小型實(shí)時(shí)操作系統(tǒng)。它由Jean JLabrosse1992年推出第l版,立刻在嵌入式系統(tǒng)領(lǐng)域引起強(qiáng)烈反響。μCOS II是一個(gè)基于搶占式的實(shí)時(shí)多任務(wù)內(nèi)核,可固化、可剪裁、具有高穩(wěn)定性和可靠性。它最鮮明特點(diǎn)就是源碼公開(kāi),便于移植和維護(hù),而且對(duì)于學(xué)校研究完全免費(fèi),只有在應(yīng)用于盈利項(xiàng)目時(shí)才需要支付少量的版權(quán)費(fèi),特別適合一般使用者的學(xué)習(xí)、研究和開(kāi)發(fā)。自問(wèn)世以來(lái),其穩(wěn)定性和可靠性得到了廣泛的認(rèn)可,現(xiàn)已經(jīng)通過(guò)美國(guó)FAA認(rèn)證。在嵌入式領(lǐng)域,μcOS憑借優(yōu)越特性得到了越來(lái)越廣泛的應(yīng)用,眾多的研究開(kāi)發(fā)者將其作為操作系統(tǒng)的樣板,移植到各種硬件平臺(tái),其外圍的應(yīng)用也越來(lái)越多。

 

1 μC0S在嵌入式產(chǎn)品應(yīng)用中存在的問(wèn)題

隨著移動(dòng)通信、信息家電以及工業(yè)控制等領(lǐng)域的快速發(fā)展,嵌入式軟件產(chǎn)業(yè)迎來(lái)了極佳的發(fā)展時(shí)機(jī)。強(qiáng)勁的市場(chǎng)需求帶來(lái)了研發(fā)的快速增長(zhǎng),越來(lái)越多的軟件公司投入到嵌入式產(chǎn)品的研發(fā)中。但另一方面,大部分軟件公司卻缺乏嵌入式操作系統(tǒng)這個(gè)嵌入式產(chǎn)品的核心技術(shù),無(wú)法提供給各種應(yīng)用多任務(wù)等現(xiàn)代操作系統(tǒng)所必備的功能,極大地限制了產(chǎn)品的性能和發(fā)展。μCOS具有源碼公開(kāi),商業(yè)授權(quán)費(fèi)極低等特點(diǎn),成為嵌入式產(chǎn)品開(kāi)發(fā)的一種選擇。


    μ
COSII在設(shè)計(jì)時(shí)強(qiáng)調(diào)實(shí)時(shí)性。它采用單一的基于優(yōu)先級(jí)的搶先式調(diào)度算法,有效地保證了實(shí)時(shí)性的要求。在各種嵌入式操作系統(tǒng)中,其任務(wù)切換帶來(lái)的時(shí)延窗口很小。非常適合強(qiáng)實(shí)時(shí)性的任務(wù)要求,但是對(duì)于大部分周期性和實(shí)時(shí)性要求不高的任務(wù)來(lái)說(shuō),μCOII還存在一些不足:


    ①缺乏時(shí)間片調(diào)度,低優(yōu)先級(jí)的任務(wù)很難得到執(zhí)行。μ
COSII不支持時(shí)間片調(diào)度,優(yōu)先級(jí)高的任務(wù)如果不主動(dòng)放棄CPU,低優(yōu)先級(jí)任務(wù)永遠(yuǎn)都不可能運(yùn)行。這對(duì)于那些分別編寫,但叉可能同時(shí)運(yùn)行的任務(wù)來(lái)說(shuō),只能通過(guò)任務(wù)之間的同步等動(dòng)作來(lái)完成交替運(yùn)行。這不但增加了編程難度,而且破壞了模塊的獨(dú)立性。


    ②任務(wù)創(chuàng)建和銷毀的接口復(fù)雜。μ
COSll的上層軟件開(kāi)發(fā)需要關(guān)心底層具體實(shí)現(xiàn),接口比較復(fù)雜。對(duì)于經(jīng)驗(yàn)不多的程序員來(lái)說(shuō),第一,創(chuàng)建任務(wù)時(shí)需要用戶自行指定優(yōu)先級(jí)。這必然牽涉到如何管理分配優(yōu)先級(jí)的問(wèn)題。第二,μCOSII中任務(wù)的棧空間完全由用戶管理,系統(tǒng)只是簡(jiǎn)單地要求用戶創(chuàng)建任務(wù)時(shí)傳人棧地址,而不參與??臻g的申請(qǐng)和釋放。為了簡(jiǎn)化μCOS的示例程序,更是簡(jiǎn)單地以靜態(tài)數(shù)組作為任務(wù)棧。??臻g的放任自流在帶來(lái)一定靈活性的同時(shí)也會(huì)帶來(lái)問(wèn)題的隱患。第三,因?yàn)棣?/SPAN>COSII規(guī)定任務(wù)必須為無(wú)限循環(huán)或自銷毀形式,所以其任務(wù)在結(jié)束時(shí),需要手工調(diào)用OSTaskDel,使該任務(wù)進(jìn)入睡眠態(tài),不能簡(jiǎn)單地返回。與現(xiàn)在流行的大多數(shù)操作系統(tǒng)用法差異較大。


    結(jié)合國(guó)內(nèi)的產(chǎn)業(yè)現(xiàn)狀,從程序員素質(zhì)和應(yīng)用程序的實(shí)時(shí)性分類,在數(shù)量上都呈現(xiàn)金字塔狀;而且往往是高級(jí)程序員負(fù)責(zé)開(kāi)發(fā)實(shí)時(shí)應(yīng)用,普通程序員開(kāi)發(fā)非實(shí)時(shí)應(yīng)用。如果希望能在包括數(shù)目龐大的非實(shí)時(shí)應(yīng)用的產(chǎn)品中利用μ
COSII,則必須對(duì)它作出擴(kuò)充,在保留實(shí)時(shí)任務(wù)支持的前提下,增添時(shí)間片調(diào)度,并對(duì)任務(wù)的接口作出簡(jiǎn)化處理。

 

2 μCOS調(diào)度算法的改進(jìn)

μCOS中的每個(gè)任務(wù)具有一個(gè)任務(wù)控制塊0S_TCB,任務(wù)控制塊記錄任務(wù)執(zhí)行的環(huán)境,包括任務(wù)的優(yōu)先級(jí)、任務(wù)的堆棧指針、任務(wù)的相關(guān)事件控制塊指針等。內(nèi)核將系統(tǒng)中處于就緒態(tài)的任務(wù)在就緒表中進(jìn)行標(biāo)注,通過(guò)就緒表中的兩個(gè)變量OSRdyGrpOSRdyTbl[]可快速查找系統(tǒng)中就緒的任務(wù)。在μCOSII中每個(gè)任務(wù)有唯一的優(yōu)先級(jí),因此任務(wù)的優(yōu)先級(jí)也是任務(wù)的唯一標(biāo)識(shí)。內(nèi)核可用控制塊優(yōu)先級(jí)表OSTCBPrioTbl[]通過(guò)任務(wù)的優(yōu)先級(jí)查到任務(wù)控制塊的地址。μCOSII主要就是利用任務(wù)控制快OS_TCB、就緒表和控制塊優(yōu)先級(jí)表0STCBPrioTbl[]來(lái)進(jìn)行任務(wù)調(diào)度。任務(wù)調(diào)度程序OSSched()首先由就緒表中找到當(dāng)前系統(tǒng)中處于就緒態(tài)的優(yōu)先級(jí)最高的任務(wù),然后根據(jù)其優(yōu)先級(jí)由控制塊優(yōu)先級(jí)表0STCBPrioTbl[]取得相應(yīng)任務(wù)控制塊的地址,由OS_TASKSW()程序進(jìn)行運(yùn)行環(huán)境的切換。若在任務(wù)運(yùn)行時(shí)發(fā)生中斷,則轉(zhuǎn)向執(zhí)行中斷程序,執(zhí)行完畢后不是簡(jiǎn)單地返回中斷調(diào)用處,而是由OSIntExit()程序進(jìn)行任務(wù)調(diào)度,執(zhí)行當(dāng)前系統(tǒng)中優(yōu)先級(jí)最高的就緒態(tài)任務(wù)。


    本文擬在不破壞μ
COS實(shí)時(shí)性的前提下,增加時(shí)間片調(diào)度,以適于非實(shí)時(shí)性場(chǎng)合,并參考WindowsLinux多種通用操作系統(tǒng)任務(wù)調(diào)用接口函數(shù),對(duì)μC0S任務(wù)接口作出改進(jìn),提供通用簡(jiǎn)單的編程接口,降低應(yīng)用軟件開(kāi)發(fā)難度,增加系統(tǒng)穩(wěn)定性和可靠性。


2.1 
時(shí)間片調(diào)度算法的設(shè)計(jì)與實(shí)現(xiàn)

μCOS中共有64個(gè)任務(wù),其中作者保留了8個(gè)任務(wù)以備將來(lái)使用,因此用戶可以有多達(dá)56個(gè)應(yīng)用任務(wù)。將這些任務(wù)劃分為3個(gè)層次,如圖l所示。

 

    實(shí)時(shí)任務(wù)保留原本設(shè)計(jì)的絕對(duì)優(yōu)先級(jí)調(diào)度,對(duì)系統(tǒng)驅(qū)動(dòng)或通信等實(shí)時(shí)性要求高的場(chǎng)合提供支持,任務(wù)的創(chuàng)建接口保持不變,由高級(jí)程序員編寫相應(yīng)程序;在分時(shí)任務(wù)空間采用時(shí)間片調(diào)度,各種任務(wù)輪流執(zhí)行,適用于事務(wù)性處理或?qū)崟r(shí)性要求不高的場(chǎng)合,普通程序員在此區(qū)間內(nèi)編寫任務(wù),并對(duì)此空間任務(wù)的創(chuàng)建和銷毀提供了新的編程接口,使之適合普通程序員的編程習(xí)慣;后臺(tái)任務(wù)是指idle任務(wù)、統(tǒng)計(jì)任務(wù)等在系統(tǒng)空閑時(shí)運(yùn)行的任務(wù),其在實(shí)時(shí)任務(wù)和分時(shí)任務(wù)都沒(méi)有就緒時(shí)才有機(jī)會(huì)運(yùn)行,此區(qū)間也采用絕對(duì)優(yōu)先級(jí)調(diào)度。


    分時(shí)任務(wù)在μ
COS原先的五種狀態(tài)中添加了等待態(tài),定義為OS_STAT_WAITSLICE,表示正在等待時(shí)間片的重新產(chǎn)生。增添新?tīng)顟B(tài)后的狀態(tài)遷移如圖2所示。

 

    其中睡眠態(tài)(dormant)異于多數(shù)操作系統(tǒng)的定義,是指任務(wù)駐留在程序空間之中,還沒(méi)有交給μCOSII管理。所有任務(wù)開(kāi)始于睡眠態(tài),通過(guò)調(diào)用任務(wù)創(chuàng)立函數(shù)把任務(wù)交給μC0SII。當(dāng)任務(wù)一旦建立,就進(jìn)入就緒態(tài)準(zhǔn)備運(yùn)行。在任務(wù)銷毀時(shí),可以通過(guò)調(diào)用OSTaskDel()返回到睡眠態(tài)。其余阻塞態(tài)、就緒態(tài)、運(yùn)行態(tài)和中斷態(tài)較常見(jiàn),這里不再詳述,可以參考文獻(xiàn)[1]3章。

  
    
2中,如果處于運(yùn)行態(tài)的任務(wù)時(shí)間片消耗完畢,則該任務(wù)進(jìn)入等待狀態(tài)  如果全部分時(shí)任務(wù)都進(jìn)入等待狀態(tài),則系統(tǒng)會(huì)為其全部重新分配時(shí)間片,并使它們都返回就緒態(tài)。除此之外,其余狀態(tài)關(guān)系與μC0SIl相同。


     為了實(shí)現(xiàn)分時(shí)任務(wù)時(shí)間片調(diào)度算法,首先在
OS_TCB結(jié)構(gòu)中添加OSTCBTimeSlices,以存儲(chǔ)任務(wù)剩余的時(shí)間片數(shù);同時(shí)定義OS-NORMAL_PRIO_STARTOS_NOR-MAL_PRIO_START,表示分時(shí)任務(wù)區(qū)間的大??;還必須修改μC0S的時(shí)鐘服務(wù)程序,即函數(shù)OSTimeTick(),來(lái)處理與時(shí)鐘相關(guān)的任務(wù)狀態(tài)。修改后處理流程如圖3所示。

    3中,模塊②之前的流程與在μC()SII中幾乎完全相同,主要負(fù)責(zé)對(duì)所有任務(wù)時(shí)延值的處理。模塊②判斷處于就緒態(tài)的分時(shí)任務(wù)是否時(shí)間片用完,如是,則將其設(shè)置為等待態(tài)。模塊③查出就緒的最高優(yōu)先級(jí)任務(wù)。如果低于分時(shí)任務(wù)區(qū)間,說(shuō)明沒(méi)有分時(shí)任務(wù)或所有的分時(shí)任務(wù)都處于等待態(tài),此時(shí)為所有的分時(shí)任務(wù)重新分配新的時(shí)間片,并將其變更為就緒態(tài)。模塊④中,如果當(dāng)前任務(wù)是分時(shí)任務(wù),則說(shuō)明該任務(wù)已經(jīng)消耗了一個(gè)時(shí)間片,將該任務(wù)時(shí)間片減1


    從改進(jìn)后的處理流程可以看出,實(shí)時(shí)任務(wù)優(yōu)先級(jí)高,調(diào)度不受影響,不會(huì)進(jìn)入新加入的部分;分時(shí)任務(wù)在運(yùn)行態(tài)時(shí),其時(shí)間片會(huì)不停減少,直到剩余時(shí)間片為零,則進(jìn)入等待態(tài)。當(dāng)系統(tǒng)的所有分時(shí)任務(wù)都進(jìn)入了等待態(tài),則對(duì)在等待態(tài)的分時(shí)任務(wù)重新計(jì)算剩余時(shí)間片,并把它們都設(shè)為就緒態(tài),則新的一輪分時(shí)任務(wù)交替運(yùn)行又開(kāi)始了。所有的后臺(tái)任務(wù)的調(diào)度也不受影響。


    OSTimeTick
處理十分頻繁,必須盡可能地減少運(yùn)算開(kāi)銷,改進(jìn)方案對(duì)其增加分時(shí)任務(wù)的處理。在有實(shí)時(shí)任務(wù)運(yùn)行時(shí),延時(shí)基本沒(méi)有增加;只有在所有分時(shí)任務(wù)都進(jìn)入等待態(tài)后,才會(huì)有較大的計(jì)算量,經(jīng)試驗(yàn)效果良好。


2.2
任務(wù)接口的改進(jìn)

為了簡(jiǎn)化應(yīng)用編程接口,屏蔽低層任務(wù)管理細(xì)節(jié),為用戶提供新的任務(wù)接口OSNTaskCreateOSNTaskDel。0SNTaskCreate用于創(chuàng)建分時(shí)任務(wù),該函數(shù)在分時(shí)區(qū)間自動(dòng)分配優(yōu)先級(jí),代替用戶申請(qǐng)??臻g,并在初始化棧內(nèi)容時(shí)壓人OSNTaskDel地址。在用戶任務(wù)退出后,就會(huì)自動(dòng)調(diào)用()SNTaskDel,以釋放??臻g,并調(diào)用()STaskDel。如此更符合用戶在Windows等系統(tǒng)的情況,任務(wù)結(jié)束后只是簡(jiǎn)單返回,減小了錯(cuò)誤出現(xiàn)的機(jī)會(huì)。改進(jìn)后的OSNTaskCreate偽碼如下:


INT8U()SNTaskCreate(
任務(wù)地址pThead,參數(shù)pData,棧大小dwStackSize){在分時(shí)區(qū)間分配優(yōu)先級(jí);

if(區(qū)間已滿)

設(shè)置錯(cuò)誤碼并退出;

if(dwStackSize為零)

dwStackSize為缺省大??;

分配??臻g并記人TCB;

初始化棧空間()SNewTaskStklnit();

調(diào)用0S_TCBInit初始化TCB;

if(成功)

  調(diào)度0S_Sched();

設(shè)置錯(cuò)誤碼并退出;

}


    優(yōu)先級(jí)和??臻g分配算法較簡(jiǎn)單,這里不再詳述。新的
OSNewTaskStklnit初始化棧空間函數(shù)在x86平臺(tái)上修改前后形成的棧內(nèi)容如圖4所示。


結(jié)
  語(yǔ)

    本文對(duì)μC0SII調(diào)度算法作了改進(jìn),劃分了實(shí)時(shí)任務(wù)、分時(shí)任務(wù)和后臺(tái)任務(wù);并對(duì)任務(wù)的用戶接口進(jìn)行了改善,使之更加方便易用。以上方法已成功應(yīng)用在好易通系列電子產(chǎn)品的開(kāi)發(fā)中,對(duì)μCOSII在嵌入式產(chǎn)品應(yīng)用和推廣中具有廣泛意義。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

武漢2025年9月9日 /美通社/ -- 7月24日,2025慧聰跨業(yè)品牌巡展——湖北?武漢站在武漢中南花園酒店隆重舉辦!本次巡展由慧聰安防網(wǎng)、慧聰物聯(lián)網(wǎng)、慧聰音響燈光網(wǎng)、慧聰LED屏網(wǎng)、慧聰教育網(wǎng)聯(lián)合主辦,吸引了安防、...

關(guān)鍵字: AI 希捷 BSP 平板

上海2025年9月9日 /美通社/ -- 9月8日,移遠(yuǎn)通信宣布,其自研藍(lán)牙協(xié)議棧DynaBlue率先通過(guò)藍(lán)牙技術(shù)聯(lián)盟(SIG)BQB 6.1標(biāo)準(zhǔn)認(rèn)證。作為移遠(yuǎn)深耕短距離通信...

關(guān)鍵字: 藍(lán)牙協(xié)議棧 移遠(yuǎn)通信 COM BSP

上海2025年9月9日 /美通社/ -- 為全面落實(shí)黨中央、國(guó)務(wù)院和上海市委、市政府關(guān)于加快發(fā)展人力資源服務(wù)業(yè)的決策部署,更好發(fā)揮人力資源服務(wù)業(yè)賦能百業(yè)作用,8月29日,以"AI智領(lǐng) HR智鏈 靜候你來(lái)&quo...

關(guān)鍵字: 智能體 AI BSP 人工智能

北京2025年9月8日 /美通社/ -- 近日,易生支付與一汽出行達(dá)成合作,為其自主研發(fā)的"旗馭車管"車輛運(yùn)營(yíng)管理平臺(tái)提供全流程支付通道及技術(shù)支持。此次合作不僅提升了平臺(tái)對(duì)百余家企業(yè)客戶的運(yùn)營(yíng)管理效率...

關(guān)鍵字: 一汽 智能化 BSP SAAS

深圳2025年9月8日 /美通社/ -- 晶泰科技(2228.HK)今日宣布,由其助力智擎生技制藥(PharmaEngine, Inc.)發(fā)現(xiàn)的新一代PRMT5抑制劑PEP0...

關(guān)鍵字: 泰科 AI MT BSP

上海2025年9月5日 /美通社/ -- 由上海市經(jīng)濟(jì)和信息化委員會(huì)、上海市發(fā)展和改革委員會(huì)、上海市商務(wù)委員會(huì)、上海市教育委員會(huì)、上海市科學(xué)技術(shù)委員會(huì)指導(dǎo),東浩蘭生(集團(tuán))有限公司主辦,東浩蘭生會(huì)展集團(tuán)上海工業(yè)商務(wù)展覽有...

關(guān)鍵字: 電子 BSP 芯片 自動(dòng)駕駛

推進(jìn)卓越制造,擴(kuò)大產(chǎn)能并優(yōu)化布局 蘇州2025年9月5日 /美通社/ --?耐世特汽車系統(tǒng)與蘇州工業(yè)園區(qū)管委會(huì)正式簽署備忘錄,以設(shè)立耐世特亞太總部蘇州智能制造項(xiàng)目。...

關(guān)鍵字: 智能制造 BSP 汽車系統(tǒng) 線控

慕尼黑和北京2025年9月4日 /美通社/ -- 寶馬集團(tuán)宣布,新世代首款量產(chǎn)車型BMW iX3將于9月5日全球首發(fā),9月8日震撼亮相慕尼黑車展。中國(guó)專屬版車型也將在年內(nèi)與大家見(jiàn)面,2026年在國(guó)內(nèi)投產(chǎn)。 寶馬集團(tuán)董事...

關(guān)鍵字: 寶馬 慕尼黑 BSP 數(shù)字化

北京2025年9月4日 /美通社/ --?在全球新一輪科技革命與產(chǎn)業(yè)變革的澎湃浪潮中,人工智能作為引領(lǐng)創(chuàng)新的核心驅(qū)動(dòng)力,正以前所未有的深度與廣度重塑各行業(yè)發(fā)展格局。體育領(lǐng)域深度融入科技變革浪潮,駛?cè)霐?shù)字化、智能化轉(zhuǎn)型快車...

關(guān)鍵字: 人工智能 智能體 AI BSP

上海2025年9月2日 /美通社/ -- 近日,由 ABB、Moxa(摩莎科技)等八家企業(yè)在上海聯(lián)合發(fā)起并成功舉辦"2025 Ethernet-APL 技術(shù)應(yīng)用發(fā)展大會(huì)"。會(huì)議以"破界?融合...

關(guān)鍵字: ETHERNET 智能未來(lái) BSP 工業(yè)通信
關(guān)閉