<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

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

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

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

            3.2.2 任務(wù)及實現(xiàn)

          本文引用地址:http://www.ex-cimer.com/article/85653.htm

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

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

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

           ?、谌蝿?wù)的功能是找到當(dāng)前就緒列表中優(yōu)先級最高的任務(wù),并把這個任務(wù)切換到運行狀態(tài)。在任務(wù)控制塊列表中使用任務(wù)在列表中的相對位置表示優(yōu)先級的高低,并不需要實際地對任務(wù)優(yōu)先級進行比較。算法流程如圖1所示。

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

            任務(wù)的如下:

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

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

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

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

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

            #pragma CODE_SEG DEFAULT在MC9S12DP256B的捕獲器中有一個自動增長主時鐘,每一個硬件周期驅(qū)動TCNT十1,并與TC7相比較。設(shè)置TC7=TCNT+OS_TICK_OC_CNTS(在系統(tǒng)配置文件中定義),當(dā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ù)自動檢查每個被延遲的任務(wù),當(dāng)任務(wù)的延遲周期結(jié)束后,自動將任務(wù)切換到就緒狀態(tài)。具體算法如下:

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

           ?、诋?dāng)前延遲任務(wù)的狀態(tài)字變?yōu)?時,該任務(wù)延時結(jié)束,置就緒任務(wù)列表改變標(biāo)志位。

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

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

            結(jié) 語

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

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

          上一頁 1 2 下一頁

          評論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();