當前位置:首頁 > 嵌入式 > 嵌入式軟件
[導讀]μCOSII在基于Cortex-M3核的ARM處理器上的移植

目前,嵌入式技術已被廣泛應用到汽車電子、無線通信、數(shù)碼產(chǎn)品等各個領域。嵌入式操作系統(tǒng)及嵌入式處理器技術發(fā)展迅猛,嵌入式操作系統(tǒng)典型代表有μCOS—II、μClinux、Winclow CE、VxWorks等;嵌入式處理器包括ARM、MIPS、PowerPC等。隨著軟硬件技術的發(fā)展,人們開始意識到基于嵌入式操作系統(tǒng)的程序開發(fā)模式的便利性及可靠性,并且在程序開發(fā)過程中開始傾向于從傳統(tǒng)超循環(huán)開發(fā)模式轉(zhuǎn)向基于嵌入式操作系統(tǒng)的開發(fā)模式。

1 軟硬件開發(fā)環(huán)境及處理器介紹
1.1 軟件硬開發(fā)環(huán)境
   
移植過程使用的軟件環(huán)境是RealView MDK開發(fā)套件,此產(chǎn)品是ARM公司最新推出的針對各種嵌入式處理器的軟件開發(fā)工具,該開發(fā)套件功能強大,包括了μVision3集成開發(fā)環(huán)境和RealView編譯器。使用的硬件平臺是深圳英蓓特公司推出的全功能評估板STMl03V100,其上所采用的處理器是ST意法半導體公司生產(chǎn)的32位哈佛結(jié)構(gòu)ARM處理器STM32F103VBT6,該處理器內(nèi)置ARM公司最新的Cortex—M3核,并且具有非常豐富的片上資源。
1.2 關于基于Cortex-M3的ARM處理器的介紹
   
基于Cortex—M3核的ARM處理器支持兩種模式,分別稱為線程模式和處理模式。程序可以在系統(tǒng)復位時或中斷返回時兩種情況下進入線程模式,而處理模式只能通過中斷或異常的方式來進入。處于線程模式中代碼可以分別運行在特權(quán)方式下和非特權(quán)方式下。處于處理模式中的代碼總是運行在特權(quán)方式下。運行在特權(quán)方式下的代碼對系統(tǒng)資源具有完全訪問權(quán),而運行在非特權(quán)方式下的代碼對系統(tǒng)資源的訪問權(quán)受到一定限制。處理器可以運行在Thumb狀態(tài)或Debug狀態(tài)。在指令流正常執(zhí)行期間,處理器處于Thumb狀態(tài)。當進行程序調(diào)試時,指令流可以暫停執(zhí)行,這時處理器處于Debug狀態(tài)。處理器有兩個獨立的堆棧指針,分別稱為MSP和PSP。系統(tǒng)復位時總是處于線程模式的特權(quán)方式下,并且默認使用的堆棧指針是MSP。本移植過程中假設任務總是運行在線程模式的特權(quán)方式下且總是使用堆棧指針PSP。

2 移植過程詳解
2.1 μCOS-II內(nèi)核介紹

    μCOS—II是一個實時可剝奪型操作系統(tǒng)內(nèi)核,該操作系統(tǒng)支持最多64個任務,但每個任務的優(yōu)先級必須互不相同,優(yōu)先級號小的任務比優(yōu)先級號大的任務具有更高的優(yōu)先級,并且該操作系統(tǒng)總是調(diào)度優(yōu)先級最高的就緒態(tài)任務運行。此內(nèi)核的代碼是美國人Jean J.Labrosse用C語言編寫的,具有很好的可移植性,其2.52版本通過了美國航天航空管理局的安全認證,可靠性非常高。文中所述的移植過程使用的就是該版本的源代碼。
2.2 開始移植
    μCOS—II v2.52的源代碼按照移植要求分為需要修改部分和不需要修改部分。其中需要修改源代碼的文件包括頭文件OS_CPU.H、C語言文件OS_CPU.C以及匯編格式文件OS_CPU_A.ASM。
2.2.1 修改頭文件OS_CPU.H
   
頭文件OS_CPU.H中需要修改的內(nèi)容有與編譯器相關的數(shù)據(jù)類型重定義部分和與處理器相關的少量代碼。由于本移植過程中使用的是RealView編譯器,因此通過查閱此編譯器的相關說明文檔可以得到其所支持的基本數(shù)據(jù)類型,據(jù)此修改OS_CPU.H中與編譯器相關的數(shù)據(jù)類型重定義部分。修改后代碼如下所示:

   
    其中定義的數(shù)據(jù)類型OS_STK指出了處理器堆棧中的數(shù)據(jù)是32位的,OS_CPU_SR指出了處理器狀態(tài)寄存器字長也為32位。
    頭文件中與處理器相關部分代碼包括臨界區(qū)訪問處理、處理器堆棧增長方向及任務切換宏定義。臨界區(qū)代碼訪問涉及到全局中斷開關指令,由文獻可以得知關中斷和開中斷可以分別由指令CPSID i和CPSIE i實現(xiàn),文中臨界段訪問處理如下:

   
    其中INT_DIS()和INT_EN()分別對應關中斷和開中斷處理過程。
    根據(jù)文獻可知文中所使用的處理器支持的堆棧為滿遞減方式,即堆棧的增長方向是從內(nèi)存高地址向低地址方向遞減并且堆棧指針總是指向棧頂?shù)臄?shù)據(jù)。在頭文件OS_CPU.H中相應代碼只須修改一條,如下所示
    #define OS_STK_GROWTH1
    此定義中的1代表堆棧方向是向下遞減的。
    頭文件OS_CPU.H中最后一個要修改的地方是任務切換宏定義,μCOS—II內(nèi)核就是通過這個宏調(diào)用來觸發(fā)任務級的任務切換。任務切換一般是通過陷阱或軟件中斷來實現(xiàn)的,在基于Cortex—M3核的處理器中支持一條稱為超級用戶調(diào)用的指令SVC,此指令是ARM軟件中斷指令SWI的升級版。此處的宏定義代碼修改為如下形式
    #define OS_TASK_SW()OS_SVC()
    其中OS_SVC()之中包含了SVC指令,它可以由嵌入?yún)R編的方式在C語言代碼中進行定義,如下所示
    _asm void OS_SVC(void){SVCOx00}
    以上代碼以嵌入?yún)R編的方式定義了一個輸入?yún)?shù)和返回值都為空的C語言函數(shù),嵌入?yún)R編的格式在RealView編譯器的說明文檔中有詳細的說明。
2.2.2 修改C語言文件OS_CPU.C
   
根據(jù)文獻可知文件OS_CPU.C中有10個C語言函數(shù)需要編寫,這些函數(shù)中唯一必要的函數(shù)是OSTaskStkInit,其他9個函數(shù)必須聲明,但不一定要包含任何代碼。為了簡潔起見,本移植過程只編寫了OSTaskStkInit,此函數(shù)的作用是把任務堆棧初始化成好像剛發(fā)生過中斷一樣。要初始化堆棧首先必須了解微處理器在中斷發(fā)生前后的堆棧結(jié)構(gòu),根據(jù)文獻易知微處理器在中斷發(fā)生前后的堆棧結(jié)構(gòu),并且可知寄存器xPSR、PC、LR、R12、R3、R2、R1、RO是中斷時由硬件自動保存的。初始化時需要注意的地方是xPSR、PC和LR的初值,對于其他寄存器的初值沒有特別的要求。xPSR比特位是Thumb狀態(tài)位,初始化時須置1,否則執(zhí)行代碼時會引起一個稱為Invstate的異常,這是因為內(nèi)置Cortex—M3核的微處理器只支持Thumb和Thumb2指令集。堆棧中PC和LR須初始化為任務的入口地址值,這樣才能在任務切換時跳轉(zhuǎn)到正確的地方開始執(zhí)行。此函數(shù)可以用以下代碼來實現(xiàn)


2.2.3 修改匯編語言文件OS_CPU_A.ASM
   
匯編文件OS_CPU_A.ASM中需要編寫的函數(shù)分別為OSStartHighRdy、OSCtxSw、OSIntCtxSw和OSTickISR。第一個函數(shù)的作用是啟動多任務調(diào)度,此函數(shù)只在操作系統(tǒng)開始調(diào)度任務前執(zhí)行一次,以后不再調(diào)用。按照文獻中所述須將堆棧中的寄存器依次彈出,然后執(zhí)行一條中斷返回指令來開始第一個用戶任務的調(diào)度。但基于Cortex—M3核的ARM處理器在執(zhí)行中斷返回指令時必須處于處理模式下,否則將會引起內(nèi)存訪問異常。當系統(tǒng)上電啟動時或程序重置后,處理器會進入線程模式,而要在函數(shù)OSStartHighRdy中執(zhí)行中斷返回指令就首先需要進行模式轉(zhuǎn)換,進入處理模式,而進行同步可控制模式轉(zhuǎn)換的途徑是超級用戶調(diào)用,即通過SVC指令產(chǎn)生軟件中斷可轉(zhuǎn)換到處理模式。實際上考慮到此函數(shù)只在啟動多任務調(diào)度開始前被調(diào)用一次,并且第一次調(diào)度任務運行時任務堆棧中除了xPSR、PC和LR的初值以外,其他寄存器的初值無關緊要。因此可以簡化該函數(shù)的編寫,只須從第一個任務的堆棧中取出該任務的首地址,然后修改堆棧指針使其指向任務堆棧中內(nèi)存地址最高處,即相當于拋棄任務堆棧中所有數(shù)據(jù),最后根據(jù)取出的地址直接跳轉(zhuǎn)到任務入口地址處開始執(zhí)行。這樣可以免去軟件中斷和模式切換,從而簡化了對此函數(shù)的編寫。需要說明的是在拋棄任務堆棧中所用數(shù)據(jù)的同時也將xPSR的初值拋棄了,但這并不影響第一個任務投人運行,因為在跳轉(zhuǎn)到第一個任務運行之前,指令流是在Thumb狀態(tài)下正常執(zhí)行的,xPSR已經(jīng)有了確定的值。此函數(shù)代碼如下所示

[!--empirenews.page--]

    BX r0;直接跳轉(zhuǎn)到第一個任務的入口地址
    第二個匯編語言函數(shù)OSCtxSw是任務級的任務切換函數(shù)。若在任務執(zhí)行過程中有一個比當前任務優(yōu)先級更高的任務進入就緒態(tài),μCOS—II內(nèi)核就會啟動OSCtxSw進行任務切換。該函數(shù)會保存當前任務狀態(tài),然后恢復那個優(yōu)先級更高的任務狀態(tài),使之投入運行。前述的宏定義#defineOS_TASK_SW()OS_SVC()中的OS_SVC()包含了SVC軟件中斷指令,此中斷的中斷向量應該設為函數(shù)OSCtxSw的入口地址,即OSCtxSw是SVC指令產(chǎn)生中斷的中斷服務程序,其源代碼如下


    由于微處理器在進入中斷時按堆棧增長方向自動順序保存了如下8個寄存器:xPSR、PC、LR、R12、R3、R2、R1、R0,因此在程序中只須保存另外8個寄存器,保存順序可以隨意,但注意彈棧時要按照先進后出的方式進行。按照本文開頭的假定,任務總是運行在線程模式的特權(quán)方式下且總是使用堆棧指針PSP。而中斷產(chǎn)生后,中斷服務程序?qū)⑻幱谔幚砟J较?,并且默認使用的堆棧指針是MSP。因此在保存堆棧指針的時候需要保存的是當前任務的PSP。中斷返回前新任務的堆棧指針需要恢復到PSP中。中斷返回使用如下指令
    MOVrO,#Oxfffffffd
    BXr0
    其中立即數(shù)#0xfffffffd包含了返回信息,用這兩條指令可以使中斷返回時使用任務堆棧指針PSP,返回后任務處于線程模式且使用任務堆棧指針PSP。
    第三個匯編語言函數(shù)OSIntCtxSw與OSCtxSw類似。若任務執(zhí)行過程中產(chǎn)生了中斷,且中斷服務程序使得一個比當前被中斷的任務具有更高優(yōu)先級的任務就緒時,μCOS—II內(nèi)核就會在中斷返回之前調(diào)用函數(shù)OSIntCtxSw。在此函數(shù)中不需要像任務級任務切換函數(shù)那樣保存當前任務狀態(tài),因為當前任務已經(jīng)被中斷,在進入中斷服務程序的時候任務狀態(tài)已被保存。其源代碼與函數(shù)OSctxSw中保存當前任務堆棧PSP指令以后部分相同,此處不再列出。
    第4個匯編語言函數(shù)OSTickISR是系統(tǒng)時鐘節(jié)拍的中斷服務函數(shù)。處理器STM32F103VBT6中有一個專用系統(tǒng)時鐘節(jié)拍定時器SysTick,本移植過程使用此定時器產(chǎn)生每100 ms一次的時鐘節(jié)拍中斷。此函數(shù)源代碼如下


3 程序開發(fā)模式討論
   
傳統(tǒng)應用程序開發(fā)模式稱為超循環(huán)模式,即通常主程序是由C語言中的for語句或while語句構(gòu)成的一個無限循環(huán),程序在此循環(huán)中檢測事件的發(fā)生,從而轉(zhuǎn)向不同的任務。這種程序開發(fā)模式有兩個主要的不足之處。首先從程序維護和可靠性的角度來看,所有任務都需要程序開發(fā)人員來進行全局性的維護,當系統(tǒng)變得龐大和復雜時,任務的維護會變得非常麻煩,同時程序的可靠性也受到影響。其次,從任務級響應時間來看,這個時間是不確定的,因為程序在循環(huán)體中檢測事件發(fā)生的位置是固定的,但事件的發(fā)生是隨機的,因此從事件發(fā)生到程序檢測到事件發(fā)生這段時間也是不確定的。
    在基于嵌入式操作系統(tǒng)的應用程序開發(fā)過程中,應用程序開發(fā)人員只需關心各個任務本身,而任務調(diào)度由操作系統(tǒng)代勞。以下的例子說明了基于μCOS—II嵌入式操作系統(tǒng)的應用程序開發(fā)模式


    其中函數(shù)SysInit的作用是根據(jù)具體應用對處理器芯片進行必要的初始化,例如對系統(tǒng)的時鐘分配以及通用輸入輸出端口配置。函數(shù)OSInit是μCOS—II操作系統(tǒng)的內(nèi)核初始化程序。第一個OSTaskCreate函數(shù)創(chuàng)建了任務Taskl,此任務的入口地址是Taskl,優(yōu)先級是0。第二個OSTaskCreate函數(shù)創(chuàng)建了任務Task2,此任務的入口地址是Task2,優(yōu)先級是1。函數(shù)OSTaskCrate還會將其創(chuàng)建的任務置于就緒態(tài)。文獻敘述了函數(shù)OSTa-skCreate的各個參數(shù)的含義。函數(shù)OSStart用于啟動多任務調(diào)度。OSTimeDly是μCOS—II內(nèi)核提供的系統(tǒng)調(diào)用函數(shù),用于延時或定時,這里的參數(shù)5表示延時5個時鐘節(jié)拍。應用程序開發(fā)人員需要做的就是通過調(diào)用μCOS—II內(nèi)核提供的任務創(chuàng)建函數(shù)OSTaskCreate將編寫好的任務程序交給操作系統(tǒng)管理。[!--empirenews.page--]
    該例中在調(diào)用OSStart后,操作系統(tǒng)發(fā)現(xiàn)任務Taskl的優(yōu)先級最高,于是操作系統(tǒng)就調(diào)度任務Taskl使其投入運行,而任務Task2暫時不能獲得處理器的使用權(quán)。任務Taskl首先點亮一個LED,然后延時一段時間,當運行到OSTimeDly處時,該任務被掛起而處于等待狀態(tài),此時任務Task2成為優(yōu)先級最高的就緒態(tài)任務,于是操作系統(tǒng)調(diào)度Task2運行。當5個時鐘節(jié)拍的延時時間結(jié)束時,系統(tǒng)時間節(jié)拍中斷服務子程序會重新將任務Taskl置于就緒狀態(tài),此時任務Taskl再一次成為優(yōu)先級最高的就緒態(tài)任務,于是操作系統(tǒng)保存任務Task2的狀態(tài),并恢復任務Taskl的狀態(tài)使其又一次獲得處理器的使用權(quán)。此后程序執(zhí)行過程將重復上述步驟??梢钥吹?,在這個例子中的現(xiàn)象是某個LED燈不停的閃爍。
    μCOS—II操作系統(tǒng)內(nèi)核是實時可剝奪型的,這意味著在任務執(zhí)行過程中或中斷服務子程序中,一旦有一個新的更高優(yōu)先級的任務就緒,內(nèi)核將立刻調(diào)度此新任務運行,這說明響應任務的時間是即刻的、確定的。
    綜上所述,基于嵌入式操作系統(tǒng)的應用程序開發(fā)過程相對于以往傳統(tǒng)應用程序開發(fā)大為簡化而且任務級響應時間也得到最優(yōu)化。


4 結(jié)束語
    通過將移植過程中修改的μCOS—II內(nèi)核代碼與上述例子中的應用程序代碼在μVision3集成開發(fā)環(huán)境中編輯整合后進行編譯、鏈接并且下載到目標硬件平臺進行長時間觀察,發(fā)現(xiàn)LED不停的閃爍,說明本移植過程是成功的。

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

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

關鍵字: 阿維塔 塞力斯 華為

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

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

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

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

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

關鍵字: 亞馬遜 解密 控制平面 BSP

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

關鍵字: 騰訊 編碼器 CPU

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

關鍵字: 華為 12nm EDA 半導體

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

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

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

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

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

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

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

關鍵字: BSP 信息技術
關閉
關閉