當(dāng)前位置:首頁 > 嵌入式 > 嵌入式軟件
[導(dǎo)讀]μC/OSII中軟件定時器的優(yōu)缺點與改進(jìn)

     μC/OSII具有小巧、性能穩(wěn)定、開源等眾多優(yōu)點,并且μC/OSII大部分用ANSI C語言編寫,系統(tǒng)的移植非常容易。在μC/OSII I2.81及以后的版本中[2],加入了對軟件定時器的支持,使得μC/OSII操作系統(tǒng)更加完善。

  μC/OSII是一種基于優(yōu)先級的搶占式操作系統(tǒng),實時性很強。而系統(tǒng)中軟件定時器沒有優(yōu)先級,回調(diào)函數(shù)順序執(zhí)行,這樣就降低了系統(tǒng)的實時性。因此,本文對軟件定時器進(jìn)行改進(jìn),定時器中加入優(yōu)先級,回調(diào)函數(shù)按優(yōu)先級執(zhí)行,從而提高系統(tǒng)的實時性。

  1  對軟件定時器的介紹

  μC/OSII系統(tǒng)中的時間管理功能包括任務(wù)延時與軟件定時器,而軟件定時器的主要作用是,對函數(shù)周期性或者一次性執(zhí)行的定時,利用軟件定時器控制塊與“定時器輪”管理軟件定時器。定時器控制塊的結(jié)構(gòu)如同任務(wù)控制塊,創(chuàng)建一個定時器時,從空閑定時器控制塊鏈表中得到一個空閑控制塊,并對其賦值。

  軟件定時器也需要一個時鐘節(jié)拍驅(qū)動,而這個驅(qū)動一般是硬件實現(xiàn)的,一般使用μC/OSII操作系統(tǒng)中任務(wù)延時的時鐘節(jié)拍來驅(qū)動軟件定時器。每個時鐘節(jié)拍OSTmrCtr(全局變量,初始值為0)增1, 當(dāng)OSTmrCtr的值等于為OS_TICKS_PER_SEC /OS_TMR_CFG_TICKS_PER_SEC(此兩者的商決定軟件定時器的頻率)時,調(diào)用函數(shù)OSTmrSignal(),此函數(shù)發(fā)送信號量OSTmrSemSignal(初始值為0,決定軟件定時器掃描任務(wù)OSTmr_Task的運行)。也就是說,對定時器的處理不在時鐘節(jié)拍中斷函數(shù)中進(jìn)行,而是以發(fā)生信號量的方式激活任務(wù)OSTmr_Task(具有很高的優(yōu)先級)。任務(wù)OSTmr_Task對定時器進(jìn)行檢測處理,包括定時器定時完成的判斷、回調(diào)函數(shù)的執(zhí)行。

  μC/OSII 2.86中與軟件定時器相關(guān)的函數(shù)包括:

  ① 軟件定時器內(nèi)部靜態(tài)函數(shù)。獲取與釋放定時器控制塊函數(shù)OSTmr_Alloc()、OSTmr_Free();定時器插入相應(yīng)“時間輪”組函數(shù)OSTmr_Link();從相應(yīng)“時間輪”組中刪除定時器函數(shù)OSTmr_Unlink();軟件定時器任務(wù)初始化函數(shù)OSTmr_InitTask();定時器掃描任務(wù)OSTmr_Task;定時器上鎖與解鎖函數(shù)OSTmr_Lock()與OSTmr_Unlock()(在μC/OSII 2.91中,此兩函數(shù)被任務(wù)調(diào)度鎖定與解鎖函數(shù)代替)。

  ② 定時器外部接口函數(shù)。定時器創(chuàng)建與刪除函數(shù)OSTmrCreate()、OSTmrDel();定時器啟動與停止函數(shù)OSTmrStart()、OSTmrStop();定時器剩余時間與當(dāng)前狀態(tài)查詢函數(shù)OSTmrRemainGet()、OSTmrStateGet();軟件定時器的初始化OSTmr_Init();發(fā)送信號量OSTmrSemSignal函數(shù)OSTmrSignal();定時器名稱查詢函數(shù)OSTmrNameGet()。

  由于軟件定時器的回調(diào)函數(shù)的執(zhí)行都是在任務(wù)OSTmr_Task中執(zhí)行,如果多個定時器同時定時完成,則在定時器任務(wù)中執(zhí)行多個定時器的回調(diào)函數(shù),因此定時器任務(wù)的執(zhí)行時間不確定。而且定時器回調(diào)函數(shù)是順序執(zhí)行的,如果某個定時器回調(diào)函數(shù)需要盡快執(zhí)行以實現(xiàn)精確定時,就難以實現(xiàn)了。由于各個定時器沒有優(yōu)先級,因此了影響系統(tǒng)的實時性。

  2  對軟件定時器的改進(jìn)

  為提高軟件定時器回調(diào)函數(shù)執(zhí)行的實時性,給每個定時器賦予一個優(yōu)先級。當(dāng)定時完成時,并且定時器的回調(diào)函數(shù)不為空,則把定時器的優(yōu)先級寫于軟件定時器就緒表中。任務(wù)OSTmr_Task對相應(yīng)“時間輪”檢查結(jié)束后,如果在掃描各個定時器前軟件定時器就緒表為零而掃描之后不為零,則發(fā)送信號量激活回調(diào)函數(shù)任務(wù)OSTmr_TaskCallback。在此任務(wù)中,回調(diào)函數(shù)根據(jù)軟件定時器就緒表中的優(yōu)先級執(zhí)行相應(yīng)的回調(diào)函數(shù),這樣就提高了系統(tǒng)的實時性。

  2.1  對軟件定時器相關(guān)數(shù)據(jù)結(jié)構(gòu)改進(jìn)

  ① 定義結(jié)構(gòu)體OS_TMR_CALL,存儲定時器的回調(diào)函數(shù)、函數(shù)的參數(shù)、定時器指針,形式如下:

  typedefstructos_tmr_call {

  OS_TMR_CALLBACKOSTmrCallback; /*回調(diào)函數(shù)*/

  void *OSTmrCallbackArg;/*回調(diào)函數(shù)指針*/

  OS_TMR *OSTmr; /*定時器指針*/

  } OS_TMR_CALL;

  在頭文件ucos_ii.h中,定義OSTmrCallbackTbl[OS_TMR_CFG_MAX],OS_TMR_CFG_MAX表示系統(tǒng)中配置的軟件定時器數(shù)量。

 ?、?在軟件定時器控制塊中加入成員變量OSTmrPrio(定時器優(yōu)先級),刪去變量OSTmrCallback(回調(diào)函數(shù))、OSTmrCallbackArg(回調(diào)函數(shù)參數(shù)),為了測試的方便,可暫不刪除這兩個變量。

 ?、?定義定時器就緒表:

  INT8UOSTmrRdyGrp;

  INT8UOSTmrRdyTbl[OS_TMR_CFG_MAX/8 + 1];

  當(dāng)定時器定時完成時,把定時器優(yōu)先級寫入就緒表,回調(diào)函數(shù)任務(wù)根據(jù)優(yōu)先級執(zhí)行回調(diào)函數(shù)。

 ?、?定義信號量OSTmrSemCallback(初始值0 ),當(dāng)定時完成后,發(fā)送此信號量,激活回調(diào)函數(shù)任務(wù),以執(zhí)行回調(diào)函數(shù)。[!--empirenews.page--]

  2.2  與軟件定時器相關(guān)的函數(shù)函數(shù)與任務(wù)的改進(jìn)

  2.2.1  軟件定時器創(chuàng)建函數(shù)OSTmrCreate

  在創(chuàng)建函數(shù)OSTmrCreate的參數(shù)中加入優(yōu)先級參數(shù)prio。調(diào)用創(chuàng)建函數(shù)時,對定時器控制塊中的成員變量賦值,并給回調(diào)函數(shù)數(shù)組的相應(yīng)單元賦值,形式如下:

  OSTmrCallbackTbl [prio].OSTmrCallback = callback;

  OSTmrCallbackTbl [prio].OSTmrCallbackArg = callback_arg;

  OSTmrCallbackTbl [prio].OSTmr = ptmr;

  2.2.2  對定時器任務(wù)OSTmr_Task的改進(jìn)

  當(dāng)有定時器定時完成,把定時器優(yōu)先級寫入軟件定時器就緒表中,并根據(jù)就緒表前后的值判斷時候發(fā)送信號量OSTmrSemSignal,以激活回調(diào)函數(shù)任務(wù)。任務(wù)OSTmr_Task的流程如圖1所示。


 


圖1  OSTmr_Task的流程

  把定時器優(yōu)先級寫入定時器就緒表的代碼如下所示:

  if (OSTmrTime == ptmr?>OSTmrMatch) {

  prio = ptmr?>OSTmrPrio;

  pfnct =OSTmrCall[prio].OSTmrCallback;

  if (pfnct != (OS_TMR_CALLBACK)0) { /*加入定時器回調(diào)函數(shù)就緒表*/

  OSTmrRdyGrp|= (INT8U)(1 《 (INT8U)(prio 》 0x03));

  OSTmrRdyTbl[prio >> 0x03]|= (INT8U)(1 《 (INT8U)(prio & 0x07));

  }

  }

  2.2.3  對定時器停止函數(shù)OSTmrStop()的修改

  函數(shù)OSTmrStop只需修改與回調(diào)函數(shù)執(zhí)行相關(guān)的部分即可,例如,case OS_TMR_OPT_CALLBACK_ARG: 部分的代碼如下:

  case OS_TMR_OPT_CALLBACK_ARG:

  prio = ptmr?>OSTmrPrio;

  pfnct = OSTmrCall[prio].OSTmrCallback;

  if (pfnct != (OS_TMR_CALLBACK)0) {

  ……/*prio加入定時器就緒表*/

  OSTmrCall[prio].OSTmrCallbackArg =(void *)callback_arg;

  OSSemPost(OSTmrSemCallback); /*發(fā)送回調(diào)函數(shù)執(zhí)行信號量*/

  }else {

  *perr = OS_ERR_TMR_NO_CALLBACK;

  }

  而case OS_TMR_OPT_CALLBACK:部分的代碼同上,只是回調(diào)函數(shù)的參數(shù)不需要重新賦值。[!--empirenews.page--]

  2.2.4  回調(diào)函數(shù)任務(wù)OSTmr_TaskCallback()

  在源文件tmr.c中加入回調(diào)函數(shù)任務(wù)OSTmr_TaskCallback(),根據(jù)定時器就緒表中的優(yōu)先級執(zhí)行相應(yīng)回調(diào)函數(shù),回調(diào)函數(shù)任務(wù)的結(jié)構(gòu)如下所示:

  static voidOSTmr_TaskCallback(void *p_arg) {……/*變量定義*/

  for (;;){//請求信號量OSTmrSemCallback

  OSSemPend(OSTmrSemCallback, 0, &err);

  OSTmr_Lock();/*定時器上鎖*/

  while (OSTmrRdyGrp) {

  ……/*從定時器就緒表中得到最高優(yōu)先級的定時器回調(diào)函數(shù)*/

  ……/*刪除就緒表中的占有位*/

  OSTmr_Unlock(); /*定時器上鎖*/

  pfnct = OSTmrCall[prio].OSTmrCallback;

 ?。?pfnct)((void *)(OSTmrCall[prio].OSTmr),OSTmrCall[prio].OSTmrCallbackArg); /*執(zhí)行回調(diào)函數(shù)*/

  OSTmr_Lock(); /*定時器上鎖*/

  }

  OSTmr_Unlock();/*定時器解鎖*/

  }

  }

  由以上代碼可知,訪問就緒表時定時器上鎖,而執(zhí)行回調(diào)函數(shù)時處于定時器解鎖狀態(tài)。如果回調(diào)函數(shù)執(zhí)行時間較長,在下一個軟件定時器節(jié)拍到來時,定時器掃描任務(wù)可以得到及時的執(zhí)行,當(dāng)前回調(diào)函數(shù)執(zhí)行完成后,可以及時得執(zhí)行就緒表中最高優(yōu)先級定時器的回調(diào)函數(shù)。由此可以看出,高優(yōu)先級定時器的回調(diào)函數(shù)得到及時執(zhí)行,系統(tǒng)的實時性提高。

  實驗測試發(fā)現(xiàn),在回調(diào)函數(shù)任務(wù)OSTmr_TaskCallback中,使用任務(wù)調(diào)度上鎖與解鎖比使用定時器上鎖與解鎖(即信號量的請求)執(zhí)行速度快一些。畢竟回調(diào)函數(shù)任務(wù)的優(yōu)先級很高(一般僅次于定時器掃描任務(wù)OSTmr_Task的優(yōu)先級),所以使用任務(wù)調(diào)度鎖定比定時器鎖定要好一些。當(dāng)然,還可以使用開關(guān)中斷的方式對就緒表進(jìn)行訪問,可以根據(jù)實際情況選擇使用哪種方式。

  3  實驗測試

  本次實驗使用軟件開發(fā)環(huán)境IAR 5.30,以基于CortexM3內(nèi)核的路虎LPC1768開發(fā)板作為硬件實驗平臺[6],對實時操作系統(tǒng)μC/OSII 2.86進(jìn)行改進(jìn)。

  對改進(jìn)后的操作系統(tǒng)進(jìn)行測試,在主函數(shù)中創(chuàng)建一個啟動任務(wù),在啟動任務(wù)中創(chuàng)建4個周期定時器(系統(tǒng)中“時間輪”數(shù)設(shè)為4),賦予不同優(yōu)先級與定時值,每個定時器控制一個LED的閃爍,啟動這4個定時器。在啟動函數(shù)中創(chuàng)建4個任務(wù),每個任務(wù)也是控制一個LED燈的閃爍(利用任務(wù)延時),之后啟動任務(wù)掛起。利用μC/OSII CSPY插件觀察各定時器的運行情況,如圖2所示。


 


圖2  軟件定時器運行界面

  經(jīng)實驗測試,系統(tǒng)運行正常,定時器回調(diào)函數(shù)得到及時的執(zhí)行,系統(tǒng)實時性得到很大的提高。

  4 結(jié)語

  軟件定時器改進(jìn)后,定時器任務(wù)的執(zhí)行時間確定,僅與同時完成定時的定時器數(shù)目有關(guān),對處于就緒表中的定時器回調(diào)函數(shù)按優(yōu)先級執(zhí)行,使高優(yōu)先級定時器的回調(diào)函數(shù)得到及時的執(zhí)行,提高了系統(tǒng)的實時性。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉