www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁(yè) > 嵌入式 > 嵌入式教程
[導(dǎo)讀]Nut/OS和μC/OS—II的實(shí)時(shí)調(diào)度算法比較

摘要  進(jìn)程調(diào)度是計(jì)算機(jī)的靈魂。在實(shí)時(shí)系統(tǒng)里,要使重要緊急的進(jìn)程一經(jīng)喚醒使被優(yōu)先調(diào)度運(yùn)行,系統(tǒng)就必須有基于進(jìn)程優(yōu)先級(jí)的實(shí)時(shí)調(diào)度策略。通過深入考察和對(duì)比μC/OS-II和Nut/OS對(duì)實(shí)時(shí)調(diào)度算法的實(shí)現(xiàn),可以深刻理解實(shí)時(shí)操作系統(tǒng)。
關(guān)鍵詞 μC/0S-II Nut/OS 實(shí)時(shí)調(diào)度算法

    如果說(shuō)CPU是計(jì)算機(jī)系統(tǒng)的心臟,那么進(jìn)程調(diào)度就是計(jì)算機(jī)系統(tǒng)的靈魂,因?yàn)樗鼪Q定了如何使用CPU。例如,Linux是一個(gè)多任務(wù)操作系統(tǒng),它的理想狀況是保持CPU有效運(yùn)行。如果某個(gè)正在運(yùn)行的進(jìn)程轉(zhuǎn)入等待系統(tǒng)資源,操作系統(tǒng)就調(diào)度其他進(jìn)程運(yùn)行,從而保證CPU的最大利用率。如何使系統(tǒng)能夠保證較短的響應(yīng)時(shí)間和較高的吞吐量,使得多個(gè)進(jìn)程競(jìng)爭(zhēng)CPU時(shí)保持公平、高效,是通用操作系統(tǒng)所追求的目標(biāo)。但對(duì)于實(shí)時(shí)操作系統(tǒng)而言,它的調(diào)度算法是基于POSIX規(guī)定的基于事件驅(qū)動(dòng)優(yōu)先級(jí)的調(diào)度算法,為了及時(shí)響應(yīng)高優(yōu)先級(jí)進(jìn)程,它寧愿犧牲整體效率。

    調(diào)度的實(shí)現(xiàn)可以分為2步來(lái)完成:
    ①何時(shí)啟動(dòng)調(diào)度,即解決調(diào)度啟動(dòng)時(shí)機(jī)的問題;
    ②怎么調(diào)度,按優(yōu)先級(jí)調(diào)度就是要找到系統(tǒng)當(dāng)前優(yōu)先級(jí)最高的進(jìn)程,然后進(jìn)行上下文切換。

    在實(shí)時(shí)系統(tǒng)中,只有當(dāng)就緒進(jìn)程集合發(fā)生變動(dòng)時(shí)才有調(diào)度的需要,而就緒進(jìn)程集合的變動(dòng)只可能發(fā)生在幾種情況下:
    ①運(yùn)行中的進(jìn)程受阻或自動(dòng)放棄CPU;
    ②系統(tǒng)中新建了進(jìn)程;
    ③運(yùn)行中的進(jìn)程“自殺”或“被殺”;
    ④運(yùn)行中的進(jìn)程喚醒了某個(gè)線程;
    ⑤中斷服務(wù)子程序結(jié)束時(shí)喚醒了其他進(jìn)程。

    理想情況下,實(shí)時(shí)系統(tǒng)在有高優(yōu)先級(jí)的進(jìn)程轉(zhuǎn)入就緒態(tài)時(shí),就應(yīng)該立即啟動(dòng)調(diào)度程序,響應(yīng)高優(yōu)先級(jí)進(jìn)程。但實(shí)際上卻存在著不可調(diào)度的時(shí)隙,稱為不可調(diào)度窗口:
    ①正在進(jìn)行進(jìn)程切換,不能進(jìn)行調(diào)度;
    ②中斷響應(yīng)期間,不能進(jìn)行調(diào)度;
    ③進(jìn)入臨界區(qū),不能進(jìn)行調(diào)度;
    ④DMA期間CPU已被掛起,不可能進(jìn)行調(diào)度。

    在實(shí)時(shí)系統(tǒng)里,必須努力縮小不可調(diào)度窗口。

    在調(diào)度啟動(dòng)的時(shí)機(jī)上,所有的實(shí)時(shí)操作系統(tǒng)基本一致。

    那么接下來(lái)要做的就是尋找系統(tǒng)中當(dāng)前最應(yīng)該得到運(yùn)行機(jī)會(huì)的進(jìn)程,下面分別看一個(gè)最簡(jiǎn)單的和比較復(fù)雜的實(shí)現(xiàn)。

1 μC/OS-Il的實(shí)現(xiàn)
   
在μC/OS-II里。只允許有64個(gè)優(yōu)先級(jí)且不同進(jìn)程優(yōu)先級(jí)互不相同。把64個(gè)優(yōu)先級(jí)分成8組,數(shù)據(jù)結(jié)構(gòu)位圖OSRdyGrp反映著哪一些進(jìn)程組中有就緒進(jìn)程。另外,各個(gè)進(jìn)程組的標(biāo)志位在位圖中的位置也是有規(guī)律的,位置靠右邊的標(biāo)志位代表優(yōu)先級(jí)較高的進(jìn)程組,只要從右到左掃描位圖OSRdyGrp,碰到第一個(gè)非0的標(biāo)志位就代表當(dāng)前優(yōu)先級(jí)最高的就緒進(jìn)程所在的進(jìn)程組。這樣,就可以預(yù)先編制一個(gè)對(duì)照表,即數(shù)組。此數(shù)組就是OStJnMapTbl[](該表的詳細(xì)描述可參閱參考文獻(xiàn)的88~90頁(yè)),以位圖OSRdyGrp的數(shù)值為下標(biāo),就可以直接得到優(yōu)先級(jí)最高者所屬組號(hào)。

    8個(gè)標(biāo)志位共有256種不同組合,所以這個(gè)數(shù)組大小是256。為了便于與μC/OS-II源代碼對(duì)照,把以O(shè)SRdyGrp的數(shù)值為下標(biāo),在OSTJnMapTbl[]數(shù)組中查得的值稱為組號(hào)y。知道組號(hào)y以后,就可以以此為下標(biāo)在OSRdyTbl[]中得到相應(yīng)的組內(nèi)位圖。同理,以這個(gè)位圖的數(shù)值OSRdyThl[y]為下標(biāo),又可以在OSUnMapTbl[]內(nèi)查得該組內(nèi)優(yōu)先級(jí)最高者進(jìn)程號(hào)。將組號(hào)和組內(nèi)號(hào)拼合在一起,就得到了目標(biāo)進(jìn)程完整的進(jìn)程號(hào),即優(yōu)先級(jí)。再以此為下標(biāo),就可以從OSTcBPrioTbl[]中得到指向目標(biāo)進(jìn)程控制塊的OSTCBHighRdy。以下就是進(jìn)程切換的工作了。

    通過上面的分析,不難理解下面這樣的語(yǔ)句了:
 

    這個(gè)過程如此簡(jiǎn)潔,其根本原因是μC/OS-II嚴(yán)格按優(yōu)先級(jí)調(diào)度,并且每個(gè)優(yōu)先級(jí)只有一個(gè)進(jìn)程。如果優(yōu)先級(jí)的使用并非唯一,多個(gè)線程可以使用相同的優(yōu)先級(jí),那就還有個(gè)相同優(yōu)先級(jí)的就緒進(jìn)程之間怎樣調(diào)度的問題,這就使調(diào)度過程復(fù)雜化了。一些商品的實(shí)時(shí)操作系統(tǒng),例如VxWorks,允許多個(gè)進(jìn)程具有相同的優(yōu)先級(jí),因?yàn)椴恢С植煌M(jìn)程可以有相同優(yōu)先級(jí)的系統(tǒng),無(wú)法采用優(yōu)先級(jí)繼承算法來(lái)解決實(shí)時(shí)系統(tǒng)里令人討厭的優(yōu)先級(jí)反轉(zhuǎn)現(xiàn)象,但它不公開源代碼。下面選擇一個(gè)公開源代碼的實(shí)時(shí)操作系統(tǒng)Nut/OS進(jìn)行分析。它有256個(gè)優(yōu)先級(jí)且允許不同進(jìn)程具有相同的優(yōu)先級(jí)。在這樣的系統(tǒng)里,是不可能采用類似于位圖這樣的機(jī)制來(lái)實(shí)現(xiàn)調(diào)度的。

2 Nut/OS的實(shí)現(xiàn)
   
為了敘述方便,設(shè)計(jì)一個(gè)完整的進(jìn)程運(yùn)行的情景來(lái)說(shuō)明。另外Nut/0S中采用了線程的概念,在不分系統(tǒng)空間和用戶空間的系統(tǒng)中,進(jìn)程等價(jià)于線程。而進(jìn)程和任務(wù)本來(lái)就是同一個(gè)概念的不同叫法。Nut/Os是一個(gè)嵌入式實(shí)時(shí)操作系統(tǒng),不分系統(tǒng)空間和用戶空間,所以以下的敘述中,線程、進(jìn)程和任務(wù)混用,意思完全一樣。

    在Nut/OS中,可以通過下面的函數(shù)創(chuàng)建一個(gè)線程:

   

    創(chuàng)建一個(gè)線程的過程,實(shí)際上就是從堆??臻g中申請(qǐng)一個(gè)放置線程控制塊的空間,在這個(gè)空間中建立線程控制塊并完成對(duì)控制塊的賦值的過程。為了更好地說(shuō)明線程控制塊的作用,下面用一個(gè)圖表來(lái)說(shuō)明,如圖1所示。

    如果創(chuàng)建成功,NutThreadCreate()將返回一個(gè)指向新創(chuàng)建的線程控制塊的指針,新創(chuàng)建的線程控制塊將放置在線程控制塊鏈表前面,nutThreadList指針總是指向這個(gè)鏈表的第一個(gè)控制快?,F(xiàn)在假設(shè)某一個(gè)應(yīng)用中只有3個(gè)線程,1個(gè)隱藏線程、1個(gè)主線程和1個(gè)應(yīng)用線程。其中隱藏線程(threads3)中創(chuàng)建了主線程(Threads2),主線程中又創(chuàng)建了應(yīng)用線程(Threadsl)。由于一開始只有一個(gè)隱藏線程,因此nutThreadList鏈表指向了隱藏線程。當(dāng)隱藏線程創(chuàng)建了主線程時(shí),主線程控制塊添加在隱藏線程控制快鏈表的前面,因此nutThreadList鏈表指向主線程。當(dāng)主線程創(chuàng)建了應(yīng)用線程,應(yīng)用線程控制塊添加在主線程控制塊的前面,因此nutThreadList鏈表改為指向應(yīng)用線程。這就組成了一個(gè)如圖2所示的鏈表。

    由圖2可知,Nut/OS采用4個(gè)鏈表來(lái)管理系統(tǒng)中的全部線程,其中runQuene總是指向全部就緒線程鏈表,這個(gè)鏈表由td_qnxt指針鏈成。td_qnxt鏈表與td_next鏈表形成機(jī)制不同。在td_next鏈表中,新創(chuàng)建的線程總是簡(jiǎn)單地放在鏈表的前面,這個(gè)鏈表包括所有的線程控制塊;而td_qnxt鏈表是根據(jù)優(yōu)先級(jí)順序排序的,一個(gè)線程只有處于就緒態(tài)(TDs_READY)或者運(yùn)行態(tài)(TDS_RUNNING)才能包括在這個(gè)鏈表中。

    隱藏線程的優(yōu)先級(jí)為254,并且總是將該線程的td_next和td_qnxt設(shè)為空指針。線程的退出機(jī)制就是將要退出的線程的優(yōu)先級(jí)設(shè)為255。由于這個(gè)線程的優(yōu)先級(jí)比隱藏線程還低,而隱藏線程又沒有指向該線程的指針,因此這個(gè)退出線程永遠(yuǎn)也不可能被運(yùn)行。

    按優(yōu)先級(jí)調(diào)度是通過mnQuene鏈表來(lái)實(shí)現(xiàn)的。Nut/OS提供了2個(gè)API來(lái)操作這個(gè)鏈表,其中插入操作的代碼如下:

   
    該API函數(shù)表明,runQuene鏈表是一個(gè)按優(yōu)先級(jí)排序的鏈表,優(yōu)先級(jí)高的線程控制塊總是在最前面,當(dāng)發(fā)現(xiàn)有相同優(yōu)先級(jí)的線程控制快時(shí),總是把后來(lái)的插到相同優(yōu)先級(jí)線程控制塊的最后面。這就自然實(shí)現(xiàn)了對(duì)相同優(yōu)先級(jí)線程按先來(lái)先服務(wù)的算法進(jìn)行調(diào)度。

    當(dāng)就緒進(jìn)程集合發(fā)生變動(dòng)時(shí),則調(diào)用NutThreadRemoveQueue()、NutThreadAddPriQueue()完成鏈表的更新讓runQuene指向更新后的鏈表頭。接下來(lái)的事就是上下文切換了。

    通過鏈表這個(gè)簡(jiǎn)單的數(shù)據(jù)結(jié)構(gòu),Nut/OS也很簡(jiǎn)潔地實(shí)現(xiàn)了實(shí)時(shí)調(diào)度算法。閱讀過Linux源代碼的人對(duì)鏈表的重要性可能更是感同身受,雖然Linux操作系統(tǒng)堪稱完美,但源代碼卻并不怎么規(guī)范,事實(shí)上造成了Linux源代碼復(fù)雜難懂;而同是開源的Nut/OS,代碼卻相當(dāng)規(guī)范,給我們提供了非常好的學(xué)習(xí)資料。筆者在這里感謝該系統(tǒng)的開發(fā)人員Harald Kipp和沈文先生等,以及那些熱愛開源并熱心奉獻(xiàn)的工程師。

結(jié)語(yǔ)
    μC/OS-II的實(shí)時(shí)性已經(jīng)通過了非常嚴(yán)格的測(cè)試,事實(shí)上成了筆者比較其他系統(tǒng)實(shí)時(shí)性能的一個(gè)基準(zhǔn)。在這次畢業(yè)設(shè)計(jì)工作中,采用Nut/OS實(shí)現(xiàn)8位機(jī)接入以太網(wǎng),運(yùn)行良好。不妨推測(cè),在一些商品實(shí)時(shí)操作系統(tǒng)里,對(duì)優(yōu)先級(jí)調(diào)度算法的實(shí)現(xiàn)采用的機(jī)制和Nut/OS是類似的。

本站聲明: 本文章由作者或相關(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)系本站刪除。
換一批
延伸閱讀

要問機(jī)器人公司哪家強(qiáng),波士頓動(dòng)力絕對(duì)是其中的佼佼者。近來(lái)年該公司在機(jī)器人研發(fā)方面獲得的一些成果令人印象深刻,比如其開發(fā)的機(jī)器人會(huì)后空翻,自主爬樓梯等。這不,波士頓動(dòng)力又發(fā)布了其機(jī)器人組團(tuán)跳男團(tuán)舞的新視頻,表演的機(jī)器人包括...

關(guān)鍵字: 機(jī)器人 BSP 工業(yè)機(jī)器人 現(xiàn)代汽車

2019年上映的《復(fù)仇者聯(lián)盟4:終局之戰(zhàn)》無(wú)疑是漫威和超級(jí)英雄粉絲心中的劇痛,該片中最受觀眾喜愛的鋼鐵俠為了打敗滅霸,一個(gè)響指也奪走了自己的生命。影片最后,復(fù)聯(lián)成員們還為鋼鐵俠舉辦了一個(gè)葬禮,一眾英雄出席讓人淚奔。鋼鐵俠...

關(guān)鍵字: 漫威 HELLO TI OS

南京2022年10月17日 /美通社/ -- 日前《2022第三屆中國(guó)高端家電品牌G50峰會(huì)》于浙江寧波落幕,來(lái)自兩百余名行業(yè)大咖、專家學(xué)者共同探討了在形勢(shì)依然嚴(yán)峻的當(dāng)下,如何以科技創(chuàng)新、高端化轉(zhuǎn)型等手段,幫助...

關(guān)鍵字: LINK AI BSP 智能家電

SAIHUB CAB 025M成功獲得安全試驗(yàn)所UL美國(guó)與加拿大認(rèn)證證書 新加坡2022年10月17日 /美通社/ -- SAI.TECH Global Corporation("SAI.TECH"...

關(guān)鍵字: AI BSP PS 清潔能源

鄭州2022年10月17日 /美通社/ -- 近日,《福布斯》發(fā)布了"2022年全球最佳雇主榜單"(The World's Best Employers 2022),中國(guó)平安再度上榜并排名全...

關(guān)鍵字: 福布斯 ST TI BSP

通過第二項(xiàng)3nm設(shè)計(jì)選用擴(kuò)展技術(shù)領(lǐng)先地位 第三季度強(qiáng)勁的貿(mào)易和設(shè)計(jì)選用反映出我們結(jié)合了IP和定制硅的混合業(yè)務(wù)模式 自2022年9月1日起,OpenFive首次并入集團(tuán) 盡管宏觀環(huán)境困難,但管理層仍對(duì)業(yè)務(wù)...

關(guān)鍵字: BSP ALPHA PEN Silicon

上海2022年10月17日 /美通社/ -- 近日,第17屆中國(guó)研究生電子設(shè)計(jì)競(jìng)賽(下簡(jiǎn)稱:研電賽)全國(guó)總決賽評(píng)審工作圓滿完成。今年,來(lái)自全國(guó)63個(gè)高校的114支參賽隊(duì)伍報(bào)名了TI企業(yè)命題,創(chuàng)下歷史新高。并且,...

關(guān)鍵字: TI 德州儀器 OS 模擬

歐洲藥品管理局人用藥品管理委員會(huì) (CHMP) 的積極建議是基于 EFFISAYIL® 1 研究結(jié)果,該研究是針對(duì)泛發(fā)性膿皰型銀屑病 (GPP) 發(fā)作患者的最大的臨床研究[1] 與斑塊狀銀屑病不同,GP...

關(guān)鍵字: HM BSP GP FOR

流體動(dòng)壓滑動(dòng)軸承為風(fēng)機(jī)發(fā)展書寫嶄新篇章 軸承滑動(dòng)層增材制造與精加工為工業(yè)級(jí)大規(guī)模生產(chǎn)鋪平道路 軸承設(shè)計(jì)從綜合性系統(tǒng)理念出發(fā) 德國(guó)施韋因富特和漢堡2022年10月17日 /美通社/ -- 舍弗勒推出了采...

關(guān)鍵字: 齒輪箱 滑動(dòng)軸承 風(fēng)力渦輪機(jī) BSP

上海2022年10月17日 /美通社/ -- Brother內(nèi)置墨倉(cāng)彩色噴墨一體機(jī)DCP-C421W新上市。此次Brother創(chuàng)新引入"按需打印,按頁(yè)付費(fèi)"...

關(guān)鍵字: DC 打印機(jī) BSP DESIGN

嵌入式教程

6897 篇文章

關(guān)注

發(fā)布文章

編輯精選

技術(shù)子站

關(guān)閉