在线看毛片网站电影-亚洲国产欧美日韩精品一区二区三区,国产欧美乱夫不卡无乱码,国产精品欧美久久久天天影视,精品一区二区三区视频在线观看,亚洲国产精品人成乱码天天看,日韩久久久一区,91精品国产91免费

<menu id="6qfwx"><li id="6qfwx"></li></menu>
    1. <menu id="6qfwx"><dl id="6qfwx"></dl></menu>

      <label id="6qfwx"><ol id="6qfwx"></ol></label><menu id="6qfwx"></menu><object id="6qfwx"><strike id="6qfwx"><noscript id="6qfwx"></noscript></strike></object>
        1. <center id="6qfwx"><dl id="6qfwx"></dl></center>

            新聞中心

            EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 一種嵌入式微調(diào)度器的實現(xiàn)方法

            一種嵌入式微調(diào)度器的實現(xiàn)方法

            作者:重慶郵電大學生 曾素華 蔣建春 時間:2008-07-14 來源:單片機與嵌入式系統(tǒng)應用 收藏

              3.2.2 任務及實現(xiàn)

            本文引用地址:http://www.biyoush.com/article/85653.htm

              這種算法已在16位單片機Motorola MC9S12DP256B和8位單片機AT89C52上實現(xiàn)。一些與硬件相關的算法,主要給出在MC9S12DP256B上的算法實現(xiàn)。

             ?、俳⑷蝿誒s_Task_Create()算法。任務創(chuàng)建函數(shù)代碼如下:

              該程序表示了系統(tǒng)建立任務的過程。如上節(jié)所述每個任務對應一個優(yōu)先級,所以任務ID也可表示任務的優(yōu)先級。建立任務的過程就是,把任務控制塊數(shù)組的任務人口地址對應ID(即任務優(yōu)先級)的任務控制塊的任務入口地址指向任務函數(shù)的地址,并初始化該任務的任務堆棧。

             ?、谌蝿?a class="contentlabel" href="http://www.biyoush.com/news/listbylabel/label/調(diào)度算法">調(diào)度算法的功能是找到當前就緒列表中優(yōu)先級最高的任務,并把這個任務切換到運行狀態(tài)。在任務控制塊列表中使用任務在列表中的相對位置表示優(yōu)先級的高低,并不需要實際地對任務優(yōu)先級進行比較。算法流程如圖1所示。

              從任務控制塊隊列的頭部(即任務優(yōu)先級為0的任務)開始依次檢查任務就緒標志(os_tcb.state),如果當前任務標志≠1,表示當前任務為非就緒狀態(tài),繼續(xù)檢查下一優(yōu)先級的任務。如果當前任務標志為1,則找到最高優(yōu)先級任務退出循環(huán),調(diào)用任務調(diào)度函數(shù)進行任務狀態(tài)切換。

              任務的如下:

              任務級切換函數(shù)需要改變程序計數(shù)器(PC),所以必須通過軟中斷實現(xiàn)。在軟中斷服務函數(shù)中改變當前運行任務的TCB指針到最高優(yōu)先級就緒任務,執(zhí)行中斷返回指令在新的任務堆棧中彈出最高優(yōu)先級任務的PSW和PC指針,從而完成任務切換。

              ③任務狀態(tài)轉換主要是激活任務os_Task_Active()、掛起任務os_Task_Suspend()和延遲任務os_Task_Delay()。掛起任務使任務進入掛起狀態(tài),延遲任務使任務進入等待狀態(tài),而激活任務函數(shù)可以使任務從掛起狀態(tài)或者等待狀態(tài)直接進入就緒狀態(tài)。任務的狀態(tài)由任務控制塊中的任務狀態(tài)字(os_tcb.state)給出。當os_tcb.state=1時表示任務進入就緒狀態(tài);當os_tcb.state=0時表示任務處于掛起狀態(tài);當os_tcb.state>1時表示任務等待os_tcb.state-1個系統(tǒng)時鐘間隔之后進入就緒狀態(tài)。任務狀態(tài)切換示意圖如圖2所示。

             ?、苡捎谶@些中低端的儀器儀表每個任務的執(zhí)行時間都比較短,為了避免優(yōu)先級反轉和死鎖,采用非搶占式調(diào)度方式,進入就緒態(tài)的任務必須在當前任務執(zhí)行完成后才能被調(diào)度。調(diào)度時處于就緒表中優(yōu)先級最高的任務進入運行。

              3.2.3 調(diào)度算法的時鐘驅動

              時間驅動需要硬件提供時鐘節(jié)拍來實現(xiàn)任務的定時。時鐘節(jié)拍信號源可以是專門的硬件定時器,比如AT89C52中的Timer2。也可以使用其他更精確的方式提供系統(tǒng)時鐘節(jié)拍。在這里使用MC9S12DP256B捕獲器的第7個通道來實現(xiàn),時鐘中斷處理函數(shù)如下:

              #pragma CODE_SEG DEFAULT在MC9S12DP256B的捕獲器中有一個自動增長主時鐘,每一個硬件周期驅動TCNT十1,并與TC7相比較。設置TC7=TCNT+OS_TICK_OC_CNTS(在系統(tǒng)配置文件中定義),當度過OS_TICK_OC_CNTS個硬件周期時,TCNT=TC7則產(chǎn)生中斷。在中斷中調(diào)用系統(tǒng)時鐘節(jié)拍函數(shù)提供精確的系統(tǒng)時鐘節(jié)拍,并再次初始化TC7=TCNT+OS_TICK_OC_CNTS,產(chǎn)生下一個時鐘節(jié)拍。

              系統(tǒng)時鐘節(jié)拍函數(shù)自動檢查每個被延遲的任務,當任務的延遲周期結束后,自動將任務切換到就緒狀態(tài)。具體算法如下:

              ①從任務控制塊列表頭部開始順序檢查各任務狀態(tài)字,將所有延遲任務的任務狀態(tài)字減1。

             ?、诋斍把舆t任務的狀態(tài)字變?yōu)?時,該任務延時結束,置就緒任務列表改變標志位。

              ③恢復被中斷任務狀態(tài),返回中斷。

              系統(tǒng)時鐘驅動代碼如下:

              結 語

              本文提出的任務調(diào)度算法是一個應用于系統(tǒng)的中間件,目的是良好地管理CPU資源,提供方便的用戶應用接口,具有良好的可移植性、時間性能和空間性能。在具有大量周期性任務的輕量級的應用中,性能和易用性的提高是非常明顯的。該算法已經(jīng)成功應用于車載的圖形操作系統(tǒng)中。

            linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)

            上一頁 1 2 下一頁

            評論


            相關推薦

            技術專區(qū)

            關閉