chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

使用搶占式的調(diào)度策略簡(jiǎn)化嵌入式系統(tǒng)設(shè)計(jì)

電子設(shè)計(jì) ? 來(lái)源:?jiǎn)纹瑱C(jī)與嵌入式系統(tǒng)應(yīng)用 ? 作者:Jean Labrosse,Micha ? 2020-09-09 18:29 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

作者:Jean Labrosse,Michael Barr,周東,何小慶

引 言

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

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

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

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

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

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

1 偽并行

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

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

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

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

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

使用搶占式的調(diào)度策略簡(jiǎn)化嵌入式系統(tǒng)設(shè)計(jì)

2 任務(wù)控制

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

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

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

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

3 權(quán) 衡

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

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

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

責(zé)任編輯:gt

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 處理器
    +關(guān)注

    關(guān)注

    68

    文章

    20160

    瀏覽量

    247710
  • 嵌入式
    +關(guān)注

    關(guān)注

    5188

    文章

    20181

    瀏覽量

    329277
  • PC
    PC
    +關(guān)注

    關(guān)注

    9

    文章

    2164

    瀏覽量

    158537
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    一種基于單片機(jī)的搶占實(shí)時(shí)嵌入式操作系統(tǒng)設(shè)計(jì)

    一種基于單片機(jī)的搶占實(shí)時(shí)嵌入式操作系統(tǒng)設(shè)計(jì)
    發(fā)表于 04-22 12:59

    嵌入式系統(tǒng)知識(shí):實(shí)時(shí)系統(tǒng)調(diào)度

    調(diào)度:給定一組實(shí)時(shí)任務(wù)和系統(tǒng)資源,確定每個(gè)任務(wù)何時(shí)何地執(zhí)行的整個(gè)過(guò)程?!? § 搶占調(diào)度:通常是優(yōu)先級(jí)驅(qū)動(dòng)的
    發(fā)表于 03-28 13:21

    什么是嵌入式系統(tǒng)?

    的任務(wù)調(diào)度保證了系統(tǒng)的實(shí)時(shí)性,但是,如果任務(wù)之間搶占 CPU 控制權(quán)處理不好,會(huì)產(chǎn)生 系統(tǒng)崩潰 、死機(jī)等嚴(yán)重后果。2. 嵌入式操作
    發(fā)表于 04-16 09:53

    嵌入式實(shí)時(shí)操作系統(tǒng)如何簡(jiǎn)化應(yīng)用軟件的設(shè)計(jì)

    嵌入式領(lǐng)域中,嵌入式實(shí)時(shí)操作系統(tǒng)(RTOS)正得到越來(lái)越廣泛的應(yīng)用。采用嵌入式實(shí)時(shí)操作系統(tǒng)可以更合理、更有效地利用CPU的資源,
    發(fā)表于 11-25 06:48

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

    嵌入式操作系統(tǒng)中的搶占調(diào)度策略是什么
    發(fā)表于 04-28 06:23

    嵌入式系統(tǒng)概論

    嵌入式系統(tǒng)概論1.嵌入式系統(tǒng):指操作系統(tǒng)和功能軟件集成于計(jì)算機(jī)硬件之中。2.嵌入式
    發(fā)表于 10-27 08:09

    嵌入式Linux操作系統(tǒng)調(diào)度算法的相關(guān)資料分享

    嵌入式Linux操作系統(tǒng)調(diào)度算法研究嵌入式操作系統(tǒng)在互聯(lián)網(wǎng)時(shí)代的今天得到廣泛應(yīng)用。Linux系統(tǒng)
    發(fā)表于 11-05 08:15

    UCOSII嵌入式操作系統(tǒng)的任務(wù)調(diào)度策略是什么

    其實(shí)整個(gè)UCOSII嵌入式操作系統(tǒng)的任務(wù)調(diào)度策略便是如此,現(xiàn)在來(lái)進(jìn)行一個(gè)總結(jié):①初始化完畢以后,系統(tǒng)啟動(dòng),某個(gè)任務(wù)在執(zhí)行中時(shí),每隔一定周期發(fā)
    發(fā)表于 12-27 06:13

    關(guān)于單片機(jī)與嵌入式系統(tǒng)之間界定

    關(guān)注、星標(biāo)公眾號(hào),直達(dá)精彩內(nèi)容一、前言二、關(guān)于單片機(jī)與嵌入式系統(tǒng)之間界定1. 單片機(jī)2.嵌入式系統(tǒng)3. 嵌入式 Linux三、非實(shí)時(shí)、軟實(shí)時(shí)
    發(fā)表于 02-23 06:27

    嵌入式實(shí)時(shí)操作系統(tǒng)VxWorks內(nèi)核調(diào)度機(jī)制分析

    本文簡(jiǎn)要介紹了多任務(wù)內(nèi)核,重點(diǎn)分析了嵌入式實(shí)時(shí)操作系統(tǒng)VxWorks的內(nèi)核調(diào)度機(jī)制——優(yōu)先級(jí)搶占調(diào)度和時(shí)間片輪轉(zhuǎn)
    發(fā)表于 12-11 16:15 ?14次下載

    嵌入式系統(tǒng)設(shè)計(jì)師備考策略

    嵌入式系統(tǒng)設(shè)計(jì)師備考策略嵌入式系統(tǒng)設(shè)計(jì)》作為嵌入式系統(tǒng)
    發(fā)表于 03-31 15:22 ?72次下載

    單片機(jī)搶占嵌入式操作系統(tǒng)

    搶占實(shí)時(shí)嵌入式操作系統(tǒng)能夠在任務(wù)得到CPU時(shí)間時(shí)第一時(shí)間進(jìn)行CPU的完全霸占,能夠更好的把握系統(tǒng)控制權(quán),從而使任務(wù)得到迅速完成。所以相較于
    發(fā)表于 01-31 17:03 ?1次下載

    嵌入式軟件接口怎么測(cè)試,嵌入式系統(tǒng)接口測(cè)試策略.doc

    嵌入式系統(tǒng)接口測(cè)試策略嵌入式系統(tǒng)接口測(cè)試策略摘要:在日益廣泛應(yīng)用的
    發(fā)表于 10-20 19:06 ?16次下載
    <b class='flag-5'>嵌入式</b>軟件接口怎么測(cè)試,<b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b>接口測(cè)試<b class='flag-5'>策略</b>.doc

    ARM嵌入式系統(tǒng)

    2018年11月1日星期四第一章:嵌入式系統(tǒng)概論1.嵌入式系統(tǒng):指操作系統(tǒng)和功能軟件集成于計(jì)算機(jī)硬件之中。2.
    發(fā)表于 10-20 19:50 ?4次下載
    ARM<b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b>

    linux嵌入式系統(tǒng)算法,嵌入式Linux操作系統(tǒng)調(diào)度算法研究

    嵌入式Linux操作系統(tǒng)調(diào)度算法研究嵌入式操作系統(tǒng)在互聯(lián)網(wǎng)時(shí)代的今天得到廣泛應(yīng)用。Linux系統(tǒng)
    發(fā)表于 11-02 10:36 ?15次下載
    linux<b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b>算法,<b class='flag-5'>嵌入式</b>Linux操作<b class='flag-5'>系統(tǒng)</b><b class='flag-5'>調(diào)度</b>算法研究