μC/OS-II中縮短中斷關(guān)閉時間的方法
出處:煙波游徒 發(fā)布于:2007-11-10 09:50:49
引 言
在實時操作系統(tǒng)中,由于是多任務(wù)的并發(fā)運行,所以在進(jìn)入一些臨界區(qū)時為了保證多任務(wù)的正常運行要關(guān)中斷。而關(guān)中斷時間是衡量一個實時操作系統(tǒng)性能的重要指標(biāo),因為外部的輸入一般都是通過中斷方式來通知系統(tǒng)的,系統(tǒng)如果關(guān)中斷時間長,必然不能及時接收中斷,對中斷的及時處理就更談不上。
更重要的是,有些應(yīng)用場合對關(guān)中斷的時間有非常嚴(yán)格的要求。例如,在電力系統(tǒng)微機(jī)繼電保護(hù)裝置中,對電流A/D采樣時,為了保障對采樣值的正確處理,定時中斷的每一個周期時間都必須及時采樣。試想,如果定時器設(shè)置的周期時間到,定時器中斷產(chǎn)生,但恰恰這時系統(tǒng)處于關(guān)中斷時間,系統(tǒng)就不能及時進(jìn)行采樣;而當(dāng)關(guān)中斷時間過長,超過一定的值時,系統(tǒng)再來進(jìn)行采樣,依據(jù)此采樣值的計算結(jié)果就會出錯。所以,在這樣的場合中,一種實時操作系統(tǒng)的關(guān)中斷時間就成為該種實時操作系統(tǒng)能否成功運用的關(guān)鍵的因素。
筆者將以μC/OS-II實時內(nèi)核為例,通過對μC/OS-II的改進(jìn),向讀者描述一種縮短實時操作系統(tǒng)中斷關(guān)閉時間的方法。之所以選擇μC/OS-II,一是因為讀者容易獲得相關(guān)代碼,國內(nèi)很多讀者也對μC/OS-II有一定程度的了解;二是因為其自身結(jié)構(gòu)簡單,適合運用于低檔嵌入式處理器,關(guān)中斷時間的問題更加突出。低檔嵌入式處理器的處理速度慢,在關(guān)中斷時間里處理相同的軟件代碼,花費的時間更長,相對地延長了關(guān)中斷時間,這時盡量從軟件著手解決關(guān)中斷時間的問題。
1 系統(tǒng)狀態(tài)標(biāo)志法概述
μC/OS-II中在進(jìn)入臨界區(qū)之前為什么要關(guān)閉中斷?通過相關(guān)資料[1]的介紹和對μC/OS-II源代碼的理解,我們知道在μC/OS-II中一旦不關(guān)中斷就進(jìn)入臨界區(qū)。當(dāng)某一任務(wù)進(jìn)入臨界區(qū)時,若恰好發(fā)生中斷,那么這時有可能引起兩種對臨界區(qū)操作的沖突:①在中斷服務(wù)程序中要操作同一臨界區(qū);②因為中斷的產(chǎn)生而引起任務(wù)的轉(zhuǎn)換,在新的任務(wù)中要操作同一臨界區(qū)。所以μC/OS-II中在進(jìn)入臨界區(qū)前要關(guān)閉中斷。
針對μC/OS-II關(guān)中斷機(jī)制的分析,考慮用一種系統(tǒng)狀態(tài)標(biāo)志法來解決這樣的臨界沖突。在μC/OS-II增加一個全局布爾變量來表示系統(tǒng)的狀態(tài),稱為"系統(tǒng)狀態(tài)標(biāo)志"。
對于μC/OS-II中所有可以在中斷中出現(xiàn)又要對臨界區(qū)操作的函數(shù),可以在進(jìn)入臨界區(qū)之前先查詢系統(tǒng)狀態(tài)標(biāo)志。如果目前系統(tǒng)沒有進(jìn)入臨界操作狀態(tài),則首先將該標(biāo)志置位,表示系統(tǒng)進(jìn)入臨界操作狀態(tài),然后該函數(shù)就可以操作臨界區(qū);而如果發(fā)現(xiàn)系統(tǒng)已進(jìn)入臨界操作狀態(tài),則將該函數(shù)對臨界區(qū)操作的部分單獨形成一個函數(shù),放到一個系統(tǒng)循環(huán)函數(shù)數(shù)組里,等待系統(tǒng)任務(wù)調(diào)度時執(zhí)行。
對于μC/OS-II中所有不可能在中斷程序中出現(xiàn)而又要對臨界區(qū)操作的函數(shù),因為函數(shù)不在中斷中出現(xiàn),所以函數(shù)開始時系統(tǒng)狀態(tài)標(biāo)志肯定不會在臨界操作狀態(tài),因此可在函數(shù)操作臨界區(qū)時直接將系統(tǒng)狀態(tài)標(biāo)志置位,表示系統(tǒng)進(jìn)入臨界操作狀態(tài),然后即可進(jìn)行臨界區(qū)的操作。
系統(tǒng)狀態(tài)標(biāo)志的復(fù)位在任務(wù)調(diào)度函數(shù)中執(zhí)行。當(dāng)然對系統(tǒng)狀態(tài)標(biāo)志的設(shè)置是要在關(guān)中斷的條件下執(zhí)行的,這應(yīng)該算是系統(tǒng)新的一個臨界區(qū)。
2 該方法的具體實現(xiàn)
下面以對μC/OS-II v2.61代碼的改進(jìn)為例,具體講解該方法的具體實現(xiàn)。
2.1 任務(wù)調(diào)度函數(shù)OS_Sched的修改
修改后的任務(wù)調(diào)度函數(shù)OS_Sched的偽代碼如下:


因為在任務(wù)調(diào)度函數(shù)OS_Sched中要執(zhí)行循環(huán)函數(shù)數(shù)組里的函數(shù),同時還要對系統(tǒng)狀態(tài)標(biāo)志復(fù)位,退出系統(tǒng)臨界操作狀態(tài),所以修改過的函數(shù)在遇到以下3種情況--該函數(shù)是在中斷里調(diào)用時、在任務(wù)調(diào)度鎖定時、當(dāng)前任務(wù)就是優(yōu)先級任務(wù)時,都將執(zhí)行系統(tǒng)循環(huán)函數(shù)數(shù)組里的函數(shù),并將系統(tǒng)狀態(tài)標(biāo)志復(fù)位,而原任務(wù)調(diào)度函數(shù)在遇到以上3種情況時是直接返回的。
2.2 增加任務(wù)重調(diào)度函數(shù)OS_Resched
任務(wù)重調(diào)度函數(shù)OS_Resched的偽代碼如下:

任務(wù)重調(diào)度函數(shù)在以下兩處執(zhí)行:
?。?) 當(dāng)μC/OS-II將當(dāng)前任務(wù)控制塊壓棧,而還沒有將優(yōu)先級任務(wù)的控制塊彈出棧時執(zhí)行,因為這時在系統(tǒng)循環(huán)函數(shù)數(shù)組里有可能還有未執(zhí)行的函數(shù),這些函數(shù)的執(zhí)行有可能導(dǎo)致另外一個更高優(yōu)先級任務(wù)的就緒。
?。?) 在中斷服務(wù)函數(shù)的末尾執(zhí)行。如果μC/OS-II中斷返回函數(shù)返回的是一個真值,則表示需要執(zhí)行重調(diào)度函數(shù),這時就要執(zhí)行重調(diào)度函數(shù)。
2.3 中斷返回函數(shù)OSIntExit的修改
中斷返回函數(shù)OSIntExit的偽代碼如下:

原函數(shù)的返回是void,而改動后的函數(shù)返回一個布爾量,用來表示下一步是要正常中斷返回(返回布爾假值時),還是要調(diào)用任務(wù)重調(diào)度函數(shù)(返回布爾真值時);同時,改動后還增加對系統(tǒng)狀態(tài)標(biāo)志的查詢,如果發(fā)現(xiàn)系統(tǒng)在臨界操作狀態(tài),則直接返回布爾假值。所以在中斷服務(wù)程序的不是象原來那樣簡單的調(diào)用,而是調(diào)用后根據(jù)返回值作相應(yīng)的處理。
2.4 信號量發(fā)送函數(shù)OSSemPoST的修改
這里將以信號量發(fā)送函數(shù)OSSemPost為例來描述對可在中斷中調(diào)用而又會對臨界區(qū)操作的函數(shù)的改進(jìn)。對于μC/OS-II中的其他函數(shù),改進(jìn)的方法大致相同。
信號量發(fā)送函數(shù)OSSemPost的偽代碼如下:

在這里,改動后的函數(shù)將先判斷系統(tǒng)狀態(tài)標(biāo)志,如果系統(tǒng)在臨界區(qū)操作狀態(tài),則將臨界操作作為另一個函數(shù)放入全局函數(shù)循環(huán)數(shù)組,等待在任務(wù)調(diào)度時執(zhí)行,如果不在臨界區(qū)操作狀態(tài),則關(guān)中斷后將系統(tǒng)狀態(tài)標(biāo)志置位,然后開中斷進(jìn)行原函數(shù)的那些臨界操作和任務(wù)調(diào)度。
2.5 信號量等待函數(shù)OSSemPend的修改
同理,這里以信號量等待函數(shù)OSSemPend為例來描述對不能在中斷中調(diào)用而又會對臨界區(qū)操作的函數(shù)的改進(jìn)。
信號量等待函數(shù)OSSemPend的偽代碼如下:

在這里,改動后的函數(shù)先將系統(tǒng)狀態(tài)標(biāo)志置位,然后進(jìn)行原來函數(shù)的臨界區(qū)操作。需要說明的是,對于函數(shù)因為等待信號量時間到、還未獲取信號量而返回的情況的處理機(jī)制,改動后的函數(shù)與原函數(shù)不同,改動后的函數(shù)將OS_EventTO函數(shù)放到時間節(jié)拍函數(shù)OSTimeTick中執(zhí)行,并將OS_EventTO函數(shù)的輸入?yún)?shù)由原來的事件pevent指針,改為任務(wù)控制塊指針ptcb,因為在函數(shù)OSTimeTick中是按照任務(wù)控制塊指針操作的。
結(jié)語
上述方法已經(jīng)在筆者的一個電力微機(jī)繼電保護(hù)項目中成功運用,該方面的實現(xiàn),提高了μC/OS-II的性能,擴(kuò)大了μC/OS-II的應(yīng)用范圍,使得單邊及工程師能更好的利用μC/OS-II提高嵌入式軟件編程水平。特別要說明的是,雖然筆者是以μC/OS-II為例來介紹的,但該方法的原理可以運用到其他實時操作系統(tǒng)上,筆者正在將該方法在實時操作系統(tǒng)RTEMS上實現(xiàn)。從這個意義上講,該方法的提出也對那些致力于編寫自己的實時操作系統(tǒng)的嵌入式軟件工程師具有借鑒意義。
版權(quán)與免責(zé)聲明
凡本網(wǎng)注明“出處:維庫電子市場網(wǎng)”的所有作品,版權(quán)均屬于維庫電子市場網(wǎng),轉(zhuǎn)載請必須注明維庫電子市場網(wǎng),http://www.hbjingang.com,違反者本網(wǎng)將追究相關(guān)法律責(zé)任。
本網(wǎng)轉(zhuǎn)載并注明自其它出處的作品,目的在于傳遞更多信息,并不代表本網(wǎng)贊同其觀點或證實其內(nèi)容的真實性,不承擔(dān)此類作品侵權(quán)行為的直接責(zé)任及連帶責(zé)任。其他媒體、網(wǎng)站或個人從本網(wǎng)轉(zhuǎn)載時,必須保留本網(wǎng)注明的作品出處,并自負(fù)版權(quán)等法律責(zé)任。
如涉及作品內(nèi)容、版權(quán)等問題,請在作品發(fā)表之日起一周內(nèi)與本網(wǎng)聯(lián)系,否則視為放棄相關(guān)權(quán)利。
- 單片機(jī)技術(shù)特性與嵌入式開發(fā)實踐指南2026/1/7 10:00:02
- 單片機(jī)(MCU)與數(shù)字信號處理器(DSP)分類及選型技術(shù)指南2025/12/30 10:02:37
- 工業(yè)級DSP信號處理系統(tǒng):硬件適配與抗干擾工程方案2025/12/15 14:41:00
- HOLTEK推出HT32F65533G/733G內(nèi)建N/N預(yù)驅(qū)電機(jī)專用SoC單片機(jī)2025/11/26 14:11:41
- 什么是C51數(shù)據(jù)類型擴(kuò)充定義2025/10/27 13:59:22
- 高速PCB信號完整性(SI)設(shè)計核心實操規(guī)范
- 鎖相環(huán)(PLL)中的環(huán)路濾波器:參數(shù)計算與穩(wěn)定性分析
- MOSFET反向恢復(fù)特性對系統(tǒng)的影響
- 電源IC在惡劣環(huán)境中的防護(hù)設(shè)計
- 連接器耐腐蝕性能測試方法
- PCB電磁兼容(EMC)設(shè)計與干擾抑制核心實操規(guī)范
- 用于相位噪聲測量的低通濾波器設(shè)計與本振凈化技術(shù)
- MOSFET在高頻開關(guān)中的EMI問題
- 電源IC在便攜式設(shè)備中的設(shè)計要點
- 連接器結(jié)構(gòu)設(shè)計常見問題分析









