国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

嵌入式操作系統(tǒng)中的搶占式調(diào)度策略

發(fā)布時間:2010-3-12 13:39    發(fā)布者:蹦蹦
關(guān)鍵詞: 操作系統(tǒng) , 嵌入式 , 搶占
引 言

通過逐行閱讀順序程序的源代碼,不難說出程序會向處理器提出什么樣的特定操作,并且也能說出這些操作的順序。實際上,如果能夠知道對一個順序程序的所有輸入,那就不僅能精確預(yù)測到處理器所執(zhí)行的一系列機器碼,還能計算出系統(tǒng)最終的輸出值或系統(tǒng)行為。這樣,無論這個程序運行的速度快慢,都能夠得到一個唯一的結(jié)果。

然而,在現(xiàn)實中順序操作程序是很少見的。譬如,在嵌入式系統(tǒng)C程序中的main()函數(shù),盡管它看上去是順序的,但是這種看似順序執(zhí)行的程序最終會被系統(tǒng)的硬件中斷,在某個時刻所打斷。當(dāng)外圍設(shè)備中斷產(chǎn)生后,相應(yīng)的中斷服務(wù)程序會運行,從而取代當(dāng)前 main()函數(shù)的執(zhí)行。這個過程就可以稱為搶占。

搶占意味著main()函數(shù)將以比預(yù)期慢的速度執(zhí)行。這是因為它執(zhí)行速度的快慢與系統(tǒng)中斷的數(shù)量、中斷程序的執(zhí)行時間以及用于保存和恢復(fù)處理器狀態(tài)的操作時間有著直接的關(guān)系。實質(zhì)上,大部分的處理器周期都被中斷服務(wù)程序給占用了。除非對中斷服務(wù)程序有時間的限制,否則,這些中斷自身并不會改變系統(tǒng)其它部分的輸出,它們只是減慢了程序的執(zhí)行。

由于絕大多數(shù)中斷服務(wù)程序處理來自于系統(tǒng)設(shè)備的中斷,這樣它們的執(zhí)行必將會帶來系統(tǒng)狀態(tài)的改變。這種狀態(tài)的改變最終會給后續(xù)指令主序列中的系統(tǒng)行為帶來變化,指令主序列則必須做出適當(dāng)?shù)姆磻?yīng)來避免狀態(tài)改變帶來的影響。此時,不但難以預(yù)測處理器將執(zhí)行的操作,同時也難以知道何時,并且以何種順序來執(zhí)行這些操作。

絕大多數(shù)處理器支持中斷的嵌套。一個打斷程序順序執(zhí)行的中斷服務(wù)程序可以被另一個更高優(yōu)先級的中斷服務(wù)程序所打斷。當(dāng)該高優(yōu)先級的中斷服務(wù)程序執(zhí)行完成后,最初的中斷可以在指令主序列之前得以繼續(xù)執(zhí)行。

當(dāng)每一個搶占過程發(fā)生時,處理器標(biāo)志位、當(dāng)前PC指針以及關(guān)鍵寄存器的內(nèi)容都應(yīng)該被保存起來(通常在RAM中),這稱為被搶占程序的上下文(context)。這些信息會在該程序進入運行態(tài)之前恢復(fù)到處理器中。在中斷事件產(chǎn)生時,大多數(shù)處理器會自動保存這些值,剩下的就是必須執(zhí)行中斷服務(wù)程序的入口和出口代碼了。

1 偽并行

一個近似的技術(shù)就是使處理器像對待處理硬件事件一樣處理軟件事件。為了達到這個目的,需要將系統(tǒng)劃分為一系列獨立的事件來處理,即任務(wù)。搶占式調(diào)度方式使這個想法成為可能。該調(diào)度方式管理著系統(tǒng)軟件對處理器的使用,并且使系統(tǒng)能夠保證對時間要求嚴(yán)格的事件得以有效的執(zhí)行。

每個任務(wù)就是一個順序執(zhí)行的函數(shù),并常常以一個無限循環(huán)作為結(jié)束。這樣,就好像任務(wù)獨占了處理器;同時,每個任務(wù)都被賦予特定的工作,如讀傳感器、掃描鍵盤、記錄一些數(shù)據(jù)或者刷新顯示等。每個任務(wù)都擁有一個相應(yīng)的優(yōu)先級,并在RAM中有屬于自己的堆棧空間。總的來說,這一系列任務(wù)一起完成了整個系統(tǒng)所要完成的功能。

當(dāng)一個高優(yōu)先級任務(wù)搶占一個低優(yōu)先級任務(wù)時,調(diào)度器所做的操作與處理器處理中斷的操作一致。首先,將當(dāng)前運行任務(wù)的上下文保存到內(nèi)存中某個地方,然后開始執(zhí)行新的任務(wù)。如果這個新任務(wù)在先前已經(jīng)運行了,那它必有一個保存的上下文,那么,則需要恢復(fù)這些內(nèi)容使其繼續(xù)運行。當(dāng)高優(yōu)先級任務(wù)執(zhí)行完后,調(diào)度器將保存其最終的上下文,并且恢復(fù)被搶占任務(wù)的運行,就好像該低優(yōu)先級任務(wù)從沒被打斷過。

經(jīng)過這樣劃分,每個任務(wù)函數(shù)可以被寫成獨占處理器的形式。在實際應(yīng)用中,往往大多數(shù)系統(tǒng)中只有一個處理器。所以在某個特定時刻應(yīng)該只有一個任務(wù)或中斷在執(zhí)行。當(dāng)沒有中斷發(fā)生時,調(diào)度器會根據(jù)就緒任務(wù)的優(yōu)先級來決定任務(wù)的運行次序。

圖1顯示了兩個不同優(yōu)先級任務(wù)和一個中斷服務(wù)程序的執(zhí)行情況。首先,中斷服務(wù)程序搶占低優(yōu)先級的任務(wù)進入運行態(tài),但是該中斷服務(wù)程序使一個更高優(yōu)先級的任務(wù)進入就緒態(tài)。所以在中斷服務(wù)程序執(zhí)行完成后,調(diào)度器選擇該高優(yōu)先級任務(wù)進入運行,這樣就推遲了恢復(fù)執(zhí)行被搶占任務(wù)的操作。需要注意的是,處理器總是認為系統(tǒng)中低優(yōu)先級的中斷比高優(yōu)先級的任務(wù)更重要。



2 任務(wù)控制

有關(guān)每個任務(wù)的信息,如任務(wù)起始地址(在C中就是函數(shù)名的地址)、任務(wù)優(yōu)先級和任務(wù)執(zhí)行需要的堆棧空間,都必須提供給調(diào)度器。系統(tǒng)調(diào)用正是利用這些信息來建立一個新的任務(wù)。盡管在不同的操作系統(tǒng)中,這些信息會有所不同,但它們的作用是一樣的。

在任務(wù)函數(shù)的實現(xiàn)體中,可能會調(diào)用與軟件事件或定時事件相關(guān)的系統(tǒng)函數(shù)。許多任務(wù)會等待一個特定類型的事件并對之作出響應(yīng)。如一些可能產(chǎn)生一個軟件事件;另一些可能做一個100ns的等待,然后再進行重復(fù)。

軟件事件和超時事件可以由其它任務(wù)或中斷服務(wù)程序來產(chǎn)生。對于后者,可以參看圖1。圖1顯示了一個中斷服務(wù)程序產(chǎn)生了一個高優(yōu)先級任務(wù)正在等待的事件(從而喚醒該任務(wù))。當(dāng)然,可能該中斷服務(wù)程序只是執(zhí)行了一個時鐘中斷,而該高優(yōu)先級任務(wù)只是等待計數(shù)器到達某一個數(shù)值。由于新的軟件事件的到來,該高優(yōu)先級任務(wù)將在下一次任務(wù)調(diào)度后投入運行。

可以采用不同方式,甚至隨機地為任務(wù)設(shè)置優(yōu)先級。然而,單調(diào)執(zhí)行率算法(RAM)為我們提供了一個理想的方法來保證關(guān)鍵任務(wù)的時間期限總能得到滿足。

3 權(quán) 衡

在使用搶占式調(diào)度策略的系統(tǒng)中,內(nèi)存消耗主要包含系統(tǒng)調(diào)用函數(shù)額外的ROM和任務(wù)堆棧使用的RAM。另一個代價就是CPU時間的損耗。例如,調(diào)度策略會消耗處理器的時鐘周期;上下文切換和時鐘節(jié)拍會消耗相當(dāng)一部分的CPU時間,特別是它們頻繁發(fā)生的情況下。

當(dāng)任務(wù)共享諸如全局變量、數(shù)據(jù)結(jié)構(gòu)或外設(shè)控制以及狀態(tài)寄存器等系統(tǒng)資源時,此時一個稱為互斥的系統(tǒng)機制被用來避免對這些共享資源競爭。互斥機制是一個避免資源競爭的有效方法;但同時它會帶來一個新的問題--優(yōu)先級反轉(zhuǎn)。

在一些應(yīng)用中,將系統(tǒng)分成一個個獨立任務(wù)來設(shè)計,并使用搶占式的調(diào)度策略。這將簡化系統(tǒng)設(shè)計,但這種方法的利弊是需要權(quán)衡的。我們只有充分考慮這些權(quán)衡條件,才能對該方法是否適合我們的應(yīng)用做出正確的判斷。

參考文獻

   1. Barr Michael.David Stewart Rate Monotonic Scheduling 2002
   2. Barr Michael.David Kalinsky Priority Inversion 2002

作 者:Jean Labrosse Michael Barr 周東 何小慶  
來 源:單片機與嵌入式系統(tǒng)應(yīng)用 2003(9)
本文地址:http://m.qingdxww.cn/thread-9275-1-1.html     【打印本頁】

本站部分文章為轉(zhuǎn)載或網(wǎng)友發(fā)布,目的在于傳遞和分享信息,并不代表本網(wǎng)贊同其觀點和對其真實性負責(zé);文章版權(quán)歸原作者及原出處所有,如涉及作品內(nèi)容、版權(quán)和其它問題,我們將根據(jù)著作權(quán)人的要求,第一時間更正或刪除。
您需要登錄后才可以發(fā)表評論 登錄 | 立即注冊

廠商推薦

  • Microchip視頻專區(qū)
  • 想要避免發(fā)生災(zāi)難,就用MPLAB® SiC電源仿真器!
  • 為何選擇集成電平轉(zhuǎn)換?
  • 基于CEC1712實現(xiàn)的處理器SPI FLASH固件安全彈性方案培訓(xùn)教程
  • 了解一下Microchip強大的PIC18-Q24 MCU系列
  • 貿(mào)澤電子(Mouser)專區(qū)

相關(guān)視頻

關(guān)于我們  -  服務(wù)條款  -  使用指南  -  站點地圖  -  友情鏈接  -  聯(lián)系我們
電子工程網(wǎng) © 版權(quán)所有   京ICP備16069177號 | 京公網(wǎng)安備11010502021702
快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 91极品在线观看 | 国产毛片精品 | 青青青青久在线观看视频 | 色偷偷7777www| 国内精品久久久久久久久久久久 | 又黄又粗 | 久久久精品2018免费观看 | 天天干天天操天天添 | 另类在线| 91亚洲综合| 欧美日韩亚洲一区二区精品 | 青青青久97在线观看香蕉 | 精品动漫在线观看视频一区 | 三级 在线播放 | 国产资源在线看 | 亚洲欧美视屏 | 九月婷婷综合 | 免费高清资源黄网站在线观看 | 99精品视频在线免费观看 | 成人精品国产 | 性欧美大战久久久久久久久 | 国产精品1024免费看 | 国产与自拍 | 久久香蕉国产线看观看网站 | 五月婷婷七月丁香 | 国产精品国产自线在线观看 | 四虎永久在线观看视频精品 | 欧美h片在线观看 | 欧洲精品视频在线观看 | 精品中文字幕一区二区三区四区 | 国产日韩一区二区三区在线观看 | 91精品观看91久久久久久 | 69视频在线观看高清免费 | 手机看片日本 | 国产馆在线观看 | 国产毛片不卡 | 99久热| 日韩手机视频 | 欧美 日韩 国产 色 欧美 日韩 成人 | 亚洲黄色中文字幕 | 亚洲欧洲日产国码一级毛片 |