當(dāng)前位置:首頁 > 嵌入式 > 嵌入式分享
[導(dǎo)讀]通常情況下,任務(wù)的優(yōu)先級是根據(jù)其重要性和緊急性來設(shè)定的。但是,在并發(fā)系統(tǒng)或多任務(wù)環(huán)境中,確實存在一種被稱為“優(yōu)先級反轉(zhuǎn)”的現(xiàn)象。


在這篇文章中,小編將為大家?guī)砬度胧綄崟r操作系統(tǒng)中的優(yōu)先級反轉(zhuǎn)問題的相關(guān)報道。如果你對本文即將要講解的內(nèi)容存在一定興趣,不妨繼續(xù)往下閱讀哦。


一、什么是嵌入式操作系統(tǒng)實時操作系統(tǒng)

嵌入式實時操作系統(tǒng)(Embedded Real-time Operation System,RTOS)。嵌入式系統(tǒng)是“用于控制、監(jiān)視或者輔助操作機器和設(shè)備的裝置”。

當(dāng)外界事件或數(shù)據(jù)產(chǎn)生時,能夠接受并以足夠快的速度予以處理,其處理的結(jié)果又能在規(guī)定的時間之內(nèi)來控制生產(chǎn)過程或?qū)μ幚硐到y(tǒng)作出快速響應(yīng),并控制所有實時任務(wù)協(xié)調(diào)一致運行的嵌入式操作系統(tǒng)。

注:在工業(yè)控制、 軍事設(shè)備、 航空航天等領(lǐng)域?qū)ο到y(tǒng)的響應(yīng)時間有苛刻的要求,這就需要使用實時系統(tǒng)。我們常常說的嵌入式操作系統(tǒng)都是嵌入式實時操作系統(tǒng)。比如μC/OS-II、eCOS和Linux、HOPEN OS。故對嵌入式實時操作系統(tǒng)的理解應(yīng)該建立在對嵌入式系統(tǒng)的理解之上加入對響應(yīng)時間的要求。

二、嵌入式實時操作系統(tǒng)中的優(yōu)先級反轉(zhuǎn)問題

通常情況下,任務(wù)的優(yōu)先級是根據(jù)其重要性和緊急性來設(shè)定的。但是,在并發(fā)系統(tǒng)或多任務(wù)環(huán)境中,確實存在一種被稱為“優(yōu)先級反轉(zhuǎn)”的現(xiàn)象。

什么時候會遇到這種現(xiàn)象?解決資源爭用問題時。

死鎖預(yù)防是實時系統(tǒng)設(shè)計中的一個重要因素。不幸的是,即使使用安全排除技術(shù),這可能也不是困難的終點。在解決資源爭用問題時,可能引入新的優(yōu)先級翻轉(zhuǎn)問題。

電電俠   能詳細解釋下優(yōu)先級反轉(zhuǎn)的原理嗎?優(yōu)先級翻轉(zhuǎn)的基本原理可以通過一個簡單的兩任務(wù)(A 和 B)系統(tǒng)的行為來解釋。

假設(shè)任務(wù)A 正在使用一個鎖定的資源,此時調(diào)度程序決定進行任務(wù)交換,新任務(wù)B希望使用 A 持有的資源。在檢查訪問機制時,發(fā)現(xiàn)資源不可用,因此任務(wù) B 掛起?;コ鈾C制按計劃執(zhí)行。但是如果 B的優(yōu)先級高于 A 呢? 結(jié)果仍然相同,B仍然被阻塞。結(jié)果是低優(yōu)先級的任務(wù) A 阻塞了高優(yōu)先級的任務(wù)B;在 A 釋放鎖定資源之前,B不能執(zhí)行。系統(tǒng)的行為表現(xiàn)得好像優(yōu)先級顛倒了一樣,即優(yōu)先級翻轉(zhuǎn)。然而,這種行為正是使用互斥時所期望的,沒什么異常。

電電俠   (若有所思)在雙任務(wù)系統(tǒng)中,性能下降可能不是一個大問題。   但是看下圖的情況。

嵌入式實時操作系統(tǒng)中的優(yōu)先級反轉(zhuǎn)問題如何引起的

這是一個四任務(wù)系統(tǒng),由任務(wù) A、B、C和 D(按照優(yōu)先級順序)組成。系統(tǒng)還包括兩個共享資源 W 和 X。請注意,為了簡化對系統(tǒng)行為的解釋,做了以下假設(shè)。

(1)上下文切換(重新調(diào)度)僅在滴答(tick)時間發(fā)生。

(2)任務(wù)可以隨時掛起。

(3)任務(wù)可以隨時就緒。

一個運行時場景

上圖示例的一個運行時場景,如下圖所示。在t0時刻,任務(wù) D正在執(zhí)行,其他任務(wù)處于掛起狀態(tài)。在下一個滴答中斷(t1時刻)發(fā)生之前,D鎖定資源W。

注意:所有其他任務(wù)都已就緒。

在t1時刻,任務(wù)A搶占D,任務(wù)D重新進入就緒(等待運行)狀態(tài)。不久之后,A 試圖使用資源W 但發(fā)現(xiàn)它被鎖定,因此任務(wù)A 掛起。t2時刻,任務(wù) B被激活,運行至完成,然后掛起。在t3時刻,任務(wù)C運行至完成并掛起。然后在t4時刻,D 再次執(zhí)行。只有當(dāng)任務(wù) D釋放資源鎖時,A 才能執(zhí)行(t5時刻)。

嵌入式實時操作系統(tǒng)中的優(yōu)先級反轉(zhuǎn)問題如何引起的

在此設(shè)計中,任務(wù)A被賦予最高優(yōu)先級,因為它是一項重要的任務(wù)。然而由于互斥機制鎖,任務(wù)A只能被迫等待所有其他任務(wù)完成后才能執(zhí)行。

電電俠   顯然這種表現(xiàn)是不能接受的, 如何才能防止“連鎖”優(yōu)先級翻轉(zhuǎn)情況的發(fā)生?   這個問題可以通過兩種方式解決,都涉及臨時提升任務(wù)優(yōu)先級。

運行任務(wù)的優(yōu)先級可以提高到通過優(yōu)先繼承技術(shù)獲取的確定值。

為共享資源分配優(yōu)先級,然后將正在運行的任務(wù)的優(yōu)先級提高到資源優(yōu)先級值,這種方式稱為優(yōu)先級天花板技術(shù)。

三、嵌入式實時操作系統(tǒng)實時性影響因素

1、縮短中斷響應(yīng)時間。

幾乎所有的實時事件都是通過中斷上報的,當(dāng)中斷來臨時,必須停止當(dāng)前的一切任務(wù),響應(yīng)中斷,把中斷分成兩部分:上半部分與下半部分,或者快中斷部分與慢中斷部分。上半部分屏蔽其他中斷,處理那些緊急任務(wù),如清除某些寄存器,保存中斷現(xiàn)場,給相應(yīng)進程發(fā)送消息等, 其他不太緊急的部分放在下半部分,此時所有中斷打開,不影響其他任務(wù)的完成。

2、縮短進程上下文切換時間。

當(dāng)CPU在執(zhí)行某個任務(wù)時,實時任務(wù)到來,需要馬上執(zhí)行實時任務(wù),不能等到當(dāng)前任務(wù)時間片用完才去執(zhí)行實時任務(wù),必須在中斷來臨之時馬上能夠切換過去,保存當(dāng)前進程的上下文如寄存器,內(nèi)存,文件,信號等上下文,恢復(fù)實時任務(wù)的上下文。保存恢復(fù)上下文越快越好,這就要求兩個進程的上下文共享的資源越少越好,如每個任務(wù)的內(nèi)存是獨立的,甚至寄存器也是獨立的,這樣互不干擾,切換最快了。

3、縮短實時進程調(diào)度時間。

一般進程都是按照優(yōu)先級調(diào)度的,實時進程的優(yōu)先級當(dāng)然要比非實時的高, 不同實時進程按緊急度不同優(yōu)先級也不同,實時進程調(diào)度算法最好與非實時部分有所區(qū)別,算法復(fù)雜度最好是O(1)。

以上便是小編此次想要和大家共同分享的內(nèi)容,如果你對本文內(nèi)容感到滿意,不妨持續(xù)關(guān)注我們網(wǎng)站喲。最后,十分感謝大家的閱讀,have a nice day!


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

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉