當(dāng)前位置:首頁 > 電源 > 數(shù)字電源
[導(dǎo)讀]MDK RL—RTX是ARM公司推出的最新實時多任務(wù)內(nèi)核,Cortex—M3是ARM公司最新發(fā)布的嵌入式處理器。將RL—RTX實時多任務(wù)內(nèi)核應(yīng)用到cortex—M3處理器上,可大大提高代碼密度,減少系統(tǒng)內(nèi)存,提升系統(tǒng)性能。本文介紹了RL—RTX在Cortex—M3上的移植以及多任務(wù)應(yīng)用設(shè)計方法。

1 MDK RL—RTX和COrtex—M3概述
   
MDK開發(fā)套件源自德國Keil公司,是ARM公司目前最新推出的針對各種嵌入式處理器的軟件開發(fā)工具。MDKRL—IUX是一個實時操作系統(tǒng)(RTOS)內(nèi)核,完全集成在MDK編譯器中。廣泛應(yīng)用于ARM7、ARM9和Cortex-M3設(shè)備中。它可以靈活解決多任務(wù)調(diào)度、維護(hù)和時序安排等問題。基于RL—I訂X的程序由標(biāo)準(zhǔn)的C語言編寫,由Real—View編譯器進(jìn)行編譯。操作系統(tǒng)依附于C語言使聲明函數(shù)更容易,不需要復(fù)雜的堆棧和變量結(jié)構(gòu)配置,大大簡化了復(fù)雜的軟件設(shè)計,縮短了項目開發(fā)周期。
    Cortex—M3是一個32位的核。它是首個基于ARMv7M架構(gòu),主要針對價格敏感但又具備高系統(tǒng)效能需求的嵌入式應(yīng)用設(shè)計,如微控制器、汽車車體系統(tǒng)及網(wǎng)絡(luò)裝置等。它內(nèi)核緊湊,性能更高,采用了Thumb一2指令集架構(gòu),中斷時間更短,標(biāo)準(zhǔn)化內(nèi)存映射,帶有內(nèi)置SysTick的集成式NVIC。SysTick能定期地產(chǎn)生異常請求,作為系統(tǒng)的時基,計時更準(zhǔn)確。
    MDK RL—RTX和Cortex—M3都源自ARM公司。ARM公司將其無縫整合在MDK開發(fā)套件中,因此將RL—RTX移植到Cortex—M3上非常適合。RL—RTX作為一個全功能的內(nèi)核,可以結(jié)合實時軟件庫中的其他組件。例如,加入實時庫中RL—Flasht文件系統(tǒng)組件,就可以讀寫標(biāo)準(zhǔn)SD卡和MMC卡上面的文件;加入RL—TCPnet組件,可應(yīng)用于HTTP Web,ServeI’、TFTP Server和SMTP Client等??蓴U(kuò)展性強(qiáng),應(yīng)用廣泛。

2 基于COrtex—M3硬件平臺的構(gòu)建
    STM32F103VB是ST公司基于Cortex—M3的處理器。它有1個128 KB Flash,1個20 KB SRAM,4個16位定時器,100個可編程的I/0引腳,具有I2C、SPI、USB、15SART和CAN接口,2路10通道12位A/D轉(zhuǎn)換器,RTC功能模塊,WDT功能和高級電源管理功能。
    系統(tǒng)的數(shù)據(jù)緩存RAM和程序存儲器Flash為芯片自帶,系統(tǒng)外接A/D轉(zhuǎn)換器構(gòu)成控制器。基于Cortex-M3核的最小系統(tǒng)框圖如圖1所示。

    基于該平臺,設(shè)計一個超溫報警器。使用美國半導(dǎo)體Dalias公司的智能溫度傳感器DS18820采樣,LCD顯示溫度數(shù)值,如果短時間內(nèi)溫度超出正常溫度,蜂鳴器發(fā)出100 dB警報且LED燈閃爍示警??梢赃M(jìn)一步在該平臺上進(jìn)行擴(kuò)展,加入GPS和GPRS模塊,當(dāng)溫度超出設(shè)定范圍時,GPS將現(xiàn)場經(jīng)緯度以及時間通過GPRS以短信方式發(fā)送給監(jiān)控中心,GPRS模塊自動撥打有關(guān)人員移動電話或固定電話報警。

3 MDK RL—RTX的配置與移植
    RL—RTX在任務(wù)管理方面不僅支持搶先式任務(wù)切換,而且支持時間片輪轉(zhuǎn)切換。在基于時間片的輪轉(zhuǎn)任務(wù)機(jī)制下,CPIJ的執(zhí)行時間被劃分為若干時間片,由RL—RTX分配一個時間片給每個任務(wù),在該時間片內(nèi)只執(zhí)行這個任務(wù)。當(dāng)時間片到,在下一個時間片中無條件地執(zhí)行另外一個任務(wù)。所有任務(wù)都輪詢一次后,再回頭執(zhí)行第一個任務(wù)。
    RL—RTX最多可以定義256個任務(wù),所有任務(wù)都可以同時激活成為就緒態(tài)。RL—RTX用戶任務(wù)具有表1所列的幾個狀態(tài)。

[!--empirenews.page--]

    一般情況下,任務(wù)切換由時間片控制,但有時需要用事件控制任務(wù)切換。RL—RTX事件主要有超時(Timeout)、間隔(Interval)和信號(Signal)三種。
    Timeout:掛起運行任務(wù)指定數(shù)量的時鐘周期,調(diào)用OS_DLY_WAIT函數(shù)的任務(wù)將被掛起,直到延時結(jié)束才返回到Ready狀態(tài),并可被再次執(zhí)行。延時時間由SysTick衡量,可以設(shè)置從1至OxFFFE的任何值。
    Interval:時間間隔,任務(wù)在該時間間隔中不運行,該時問間隔與任務(wù)執(zhí)行時間獨立。
    Signal:用于任務(wù)間通信,可以用系統(tǒng)函數(shù)進(jìn)行置位或復(fù)位。如果一個任務(wù)調(diào)用了wait函數(shù)等待Signal未置位,則該任務(wù)被掛起直到Signal置位,才返回READY狀態(tài),可再被執(zhí)行。
    RL—RTX中主要的系統(tǒng)函數(shù)說明如表2所列。

    RL—RTX為每個任務(wù)都分配了一個單獨的堆棧區(qū),各個任務(wù)所用堆棧位置是動態(tài)的,用task_id記錄各堆棧棧底位置。有多個嵌套子程序調(diào)用或使用大量的動態(tài)變量時,自由空間會被用完。使能棧檢查(Stack Checking),系統(tǒng)會執(zhí)行OS_STK_0VERFLOW()堆棧錯誤函數(shù)進(jìn)行堆棧出錯處理。RL—RTX堆棧管理如圖2所示。

    RL—RTX選擇Cortex上定時器1產(chǎn)生周期性中斷,相鄰中斷之間的時間就是時間片的長度。在其中斷服務(wù)程序中進(jìn)行任務(wù)調(diào)度,并判斷執(zhí)行了延遲函數(shù)的任務(wù)的延時時間是否到。這種周期性的中斷形成了RL—RTX的時鐘節(jié)拍。采用Cortex—M3的處理器STM32F103VB的CPU時鐘頻率為72 MHz,VPBDIV分頻值為4,輸出的時鐘頻率為18 MHz。系統(tǒng)推薦的時間片為1~lOO ms。
    使用RL—RTX,包含以下幾個步驟:
    第1步,由于RL—RTX集成在MDK開發(fā)套件中,在使用MDK創(chuàng)建工程后,需要在工程中添加RTX內(nèi)核選項。選擇Project→Options for Target,在Operating下拉框中選擇RTX內(nèi)核,使得在編譯時把RL—RTX所需的庫編譯進(jìn)去。
    第2步,在嵌入式應(yīng)用程序的開發(fā)中使用RL—RTX內(nèi)核,須對其進(jìn)行配置。復(fù)制\Keil\ARM\Startup目錄下RTX_Config.c文件到工程文件夾并添加到工程中。該文件中,部分配置參數(shù)說明如表3所列。

    基于Cortex—M3平臺的超溫報警器,可以設(shè)計3個任務(wù)并發(fā),分別進(jìn)行數(shù)據(jù)采集、數(shù)據(jù)處理和數(shù)據(jù)顯示。3個任務(wù)較小,系統(tǒng)安排的任務(wù)棧足夠使用,棧的容量以32位無符號整型定義,容量為64字。選擇硬件平臺片上定時器1。
    DSl8820具有300 ms的更新速率,在采集數(shù)據(jù)過程中,通過多次采集取平均值,數(shù)據(jù)采集任務(wù)執(zhí)行的時間為30 ms,數(shù)據(jù)處理任務(wù)執(zhí)行時間為40 ms,數(shù)據(jù)顯示任務(wù)執(zhí)行時間為20 ms。根據(jù)公式,對響應(yīng)時間的要求:t(響應(yīng)時間)=N(進(jìn)程數(shù)目)×q(時間片)??傮w響應(yīng)時間為90 ms,進(jìn)程數(shù)目為3,因此時間片設(shè)置為30 ms合適。在任務(wù)OS_IDLE_DEMON()中添加休眠代碼,空閑時系統(tǒng)休眠,降低功耗。
    第3步,復(fù)制\Keil\ARM\Startup下Retarget.c文件到工程文件夾中,并添加到工程中。

    修改文件,使其包含如下內(nèi)容:

    [!--empirenews.page--]
    該文件的目的是避免半主機(jī)方式軟件中斷,因為這時所有中斷都由RL—RTX統(tǒng)一管理。半主機(jī)是用于ARM目標(biāo)的一種機(jī)制,可將來自應(yīng)用程序代碼的輸入/輸出請求傳送至運行調(diào)試器的主機(jī)。它由一組已定義的SWI操作來實現(xiàn)。庫函數(shù)調(diào)用相應(yīng)的SWI(軟件中斷),然后調(diào)試代理程序處理SWI異常,并提供所需的與主機(jī)之間的通信。


4 應(yīng)用設(shè)計
4.1 多任務(wù)應(yīng)用設(shè)計
   
根據(jù)圖1所示的最小系統(tǒng)框圖,采用由表及里(out—side-in approach)分解應(yīng)用的方法設(shè)計多任務(wù)。該應(yīng)用的上下文框圖如圖3所示,中間的圈表示軟件應(yīng)用,矩形框表示應(yīng)用的輸入和輸出設(shè)備。箭頭標(biāo)有具體含義名,表示輸入和輸出通信的流程。

    根據(jù)上下文框圖以及避免“資源沖突”原則,將對同一個外設(shè)的訪問放在同一個設(shè)備中,無論何時切換任務(wù),都不會對任何獨立的“外設(shè)”造成影響。
    將應(yīng)用分解為4個任務(wù),RL—RTX的第一個任務(wù)必須是系統(tǒng)任務(wù)Init Task,該任務(wù)用來初始化其他3個任務(wù),任務(wù)創(chuàng)建完畢后,3個任務(wù)都處于READY狀態(tài);第2個任務(wù)t_phase_ADC Task用來讀取A/D采樣的數(shù)據(jù);第3個任務(wù)t_phase_DEA Task用來處理采樣的數(shù)據(jù);第4個任務(wù)t_phase_DIS Task用來將數(shù)據(jù)送到LCD液晶屏上,顯示、控制LED燈閃爍和蜂鳴器高頻報警。圖4顯示了任務(wù)觸發(fā)的流程。

    定義任務(wù):

   

    使用os_tsk_create創(chuàng)建任務(wù)t_phase_ADC、t_phase_DEA、t_phase_DIS。

    os_tsk_delete_self刪除自身任務(wù),實現(xiàn)任務(wù)切換。任務(wù)的創(chuàng)建和初始化是在主函數(shù)中定義的:

   

    任務(wù)初始化完畢后,3個任務(wù)都處于就緒狀態(tài)。t_phase_ADC任務(wù)用來采樣,多次采樣取平均值,通過給任務(wù)t_phase_DEA發(fā)信號signal_func(t_phase_DEA),喚醒t_phase_DEA任務(wù)。

   

    os_evt_wait_and進(jìn)行控制。該任務(wù)判斷采樣的數(shù)據(jù)是否在警戒溫度范圍內(nèi),如果出現(xiàn)溫度異常,置標(biāo)志位為1。執(zhí)行完自身任務(wù)后,通過signal_func(t_phase_DIS),將喚醒t_phase_DIS任務(wù)。

   
    t_phase_DIS任務(wù)用來在LCD液晶屏上顯示溫度值。如果發(fā)現(xiàn)標(biāo)志位為1,則LED燈閃爍和蜂鳴器高頻報警。
4.2 應(yīng)用設(shè)計測試
   
采用基本RMA可調(diào)度性測試。式1用來完成系統(tǒng)的基本RMA可調(diào)度性測試。

   
這里:Ci為與周期性任務(wù)i相關(guān)的最壞執(zhí)行時間,Ti為與任務(wù)i相關(guān)的周期,n為任務(wù)的個數(shù)。
    U(n)是利用系數(shù),式1的右邊是理論處理器利用率的上界。如果給定一組任務(wù),其處理器利用率小于理論利用率上界,則這組任務(wù)是可調(diào)度的。U的值隨n的增加而下降;當(dāng)n的值為無限時,最終收斂于69%。
    表4總結(jié)了使用RMA進(jìn)行調(diào)度的3個任務(wù)的特性。

使用式1,該應(yīng)用設(shè)計處理器利用率計算如下:


應(yīng)用設(shè)計總的利用率是27.42%,低于78%的理論邊界。此4個任務(wù)的系統(tǒng)是可調(diào)度的,該應(yīng)用設(shè)計是成功的。


結(jié) 語
    本文描述了如何在Cortex—M3上使用MDK RL—RTX的方法,并給出了一個簡單的多任務(wù)應(yīng)用設(shè)計??梢钥闯龆嗳蝿?wù)的程序設(shè)計被大大簡化了,它不但滿足多個任務(wù)的時間要求,降低了開發(fā)難度,而且程序的可讀性和可維護(hù)性也有了很大的提高。利用MDK RL—RTX構(gòu)建的嵌入式工業(yè)控制系統(tǒng)具有成本低、性能高等特點,應(yīng)用廣泛,有著良好的發(fā)展前景。

本站聲明: 本文章由作者或相關(guān)機(jī)構(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 手機(jī) 衛(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ā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

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

北京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ù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

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