<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > μC/OS-Ⅱ在A(yíng)RM7上移植方法的探討與實(shí)現

μC/OS-Ⅱ在A(yíng)RM7上移植方法的探討與實(shí)現

——
作者:林麗群,劉大茂 (福州大學(xué) 福建 福州 350002) 時(shí)間:2007-01-26 來(lái)源:《現代電子技術(shù)》 收藏

隨著(zhù)嵌入式技術(shù)的快速發(fā)展,實(shí)時(shí)多任務(wù)操作系統作為一種軟件平臺已逐步成為國際嵌入式系統的主流,目前世界上已經(jīng)有一大批成熟的實(shí)時(shí)嵌入式操作系統,通常,對嵌入式軟件的基本要求是體積小、指令速度快、具有較好的裁減性和可移植性,目前,實(shí)時(shí)操作系統很多,如vxworks,windows ce,psos,qnx,lynxos等,這些操作系統都具有高可靠性、強實(shí)時(shí)性等特點(diǎn),但他們都是商業(yè)操作系統,價(jià)格昂貴,人們往往很難接受,μc/os-ⅱ操作系統的出現是對這些商業(yè)操作系統的一個(gè)很大的沖擊。

1 μc/os-ⅱ操作系統簡(jiǎn)介

μc/os-ⅱ是源碼公開(kāi)的實(shí)時(shí)操作系統,是一個(gè)自由操作系統。程序開(kāi)發(fā)人員可以改寫(xiě)源代碼,使之符合自己的要求,裁減掉不需要的部分,使操作系統變得小巧、靈活、并且能滿(mǎn)足用戶(hù)特定操作系統的需要。為了提高系統的實(shí)時(shí)能力,μc/os-ⅱ可以將一個(gè)復雜的應用劃分為多個(gè)相互獨立的任務(wù),并根據任務(wù)的重要性來(lái)分配優(yōu)先級。任務(wù)的調度完全由μc/os-ⅱ的實(shí)時(shí)內核完成,主要包括任務(wù)的狀態(tài)管理、選擇最高優(yōu)先級的任務(wù)、執行任務(wù)和撤銷(xiāo)任務(wù)等,μc/os-ⅱ內核還負責cpu時(shí)間分配,cpu時(shí)間總是優(yōu)先分配給中斷事件,其次是任務(wù)隊列中當前優(yōu)先級最高的任務(wù),不同任務(wù)間的通信可以通過(guò)μc/os-ⅱ提供的信號量、郵箱、信息隊列等機制完成,他的絕大部分代碼是用c語(yǔ)言編寫(xiě)的,可移植性強,因此1997年以后,在國際上逐漸被廣泛采用。

2 其軟硬件體系及可移植性分析

μc/os-ⅱ核心代碼很小,程序開(kāi)發(fā)人員要把他移植到自己的目標板中只需做少量的工作。圖1是基于μc/os-ⅱ的嵌入式系統的軟硬件體系結構。

雖然μc/os-ⅱ大部分源代碼是用c語(yǔ)言寫(xiě)的,但是完成和處理器有關(guān)的代碼時(shí),還是用匯編語(yǔ)言來(lái)實(shí)現的,由圖1可以看出,μc/os-ⅱ的移植的主要工作是修改與處理器相關(guān)部分的代碼,他們集中在3個(gè)文件中,其中,os_cpu.h包含與處理器相關(guān)的常量、宏和結構體的定義;os_cpu_c.c和os_cpu_asm中定義了用于底層的任務(wù)切換,退出中斷服務(wù)程序,在cpu級屏蔽中斷、打開(kāi)中斷、對任務(wù)棧初始化以及時(shí)鐘的中斷服務(wù)程序的函數等,為了使應用程序運行于μc/os-ⅱ上,還要相應地修改應用中使用的硬件和設備驅動(dòng)。

3 μc/os-ⅱ的移植工作

3.1 與應用相關(guān)的代碼

這一部分是用戶(hù)根據自己的應用系統來(lái)定制合適的內核服務(wù)功能,包括2個(gè)文件:os_cfg.h和includes.h。

本文引用地址:http://dyxdggzs.com/article/21532.htm

os_cfg.h 用來(lái)配置內核,用戶(hù)根據需要對內核進(jìn)行修改,留下需要的部分,去掉不需要的部分,比如系統可提供的最大任務(wù)數量,是否定制郵箱服務(wù),是否提供優(yōu)先級動(dòng)態(tài)改變功能等等,所有的配置更改包括頭文件的增減均在該文件中進(jìn)行。

includes.h 系統頭文件,整個(gè)實(shí)時(shí)系統程序所需要的文件,包括了內核和用戶(hù)的頭文件,這樣使得用戶(hù)項目中的每個(gè).c文件不用分別去考慮他實(shí)際上需要哪些頭文件。

3.2 與處理器相關(guān)的代碼

這是移植中最關(guān)鍵的部分。內核將應用系統和底層硬件有機地結合成一個(gè)實(shí)時(shí)系統,要使同一個(gè)內核能適用于不同的硬件體系,就需要在內核和硬件之間有一個(gè)中間層,這就是與處理器相關(guān)的代碼,處理器不同,這部分代碼也不同,我們在移植時(shí)需要自己處理這部分代碼,在μc/os中這一部分代碼分成3個(gè)文件:os_cpu.h,os_cpu_a.asm,os_cpu_c.c。

3.2.1 os_cpu.h

包含了用#define定義的與處理器相關(guān)的常量、宏和類(lèi)型定義,具體有系統數據類(lèi)型定義、棧增長(cháng)方向定義、關(guān)中斷和開(kāi)中斷定義、系統軟中斷的定義等。

(1)不依賴(lài)于編譯的數據類(lèi)型

μc/os-ⅱ不使用c語(yǔ)言中的short,int和long等數據類(lèi)型的定義,因為他們與處理器類(lèi)型有關(guān),隱含著(zhù)不可移植性,代之以移植性強的整數數據類(lèi)型,這樣,既直觀(guān)又可移植。根據ads編譯器的特性,代碼為:

typedef unsigned char boolean;
typedef unsigned char int8u;
typedef signed char int8s;
typedef unsigned short int16u;
typedef signed short int16s;
typedef unsigned int int32u;
typedef signed int int32s;
typedef float fp32;
typedef double fp64;
typedef int32u os_stk;

(2)使用軟中斷swi做底層接口

因為帶t變量的arm7處理器核具有兩個(gè)指令集,用戶(hù)任務(wù)可以使用兩種處理器模式,為了使底層接口函數與處理器狀態(tài)無(wú)關(guān),同時(shí)在任務(wù)調用相應函數時(shí)不需要知道該函數位置,本例使用軟中斷指令swi作為底層接口,使用不同的功能號區分不同的函數,其swi服務(wù)函數代碼為:

(3)os_stk_growth

μc/os-ⅱ使用結構常量os_stk_growth指定堆棧的生長(cháng)方式,其代碼為:

#define os_stk_growth 1

3.2.2 os_cpu_c.c

包含了與移植有關(guān)的c函數,包括堆棧的初始化和一些鉤子函數的實(shí)現,但是最重要的是ostaskstkinit()函數,該函數是在用戶(hù)建立任務(wù)時(shí)系統內部自己調用的,用來(lái)對用戶(hù)任務(wù)的堆棧初始化。在arm7體系結構下,任務(wù)堆??臻g由高至低遞減,依次保存著(zhù)pc,lr,r12,…,r1,r0,cpsr的初始化堆棧結構,當用戶(hù)初始化了堆棧,ostaskstkinit()就返回新的堆棧指針stk所指的定地址。ostaskcreate()和ostaskcreateext()會(huì )獲得該地址并將他保存到任務(wù)控制塊tcb中,其他的幾個(gè)鉤子函數必須聲明,但可以不包含任務(wù)代碼,這些鉤子函數在本移植中全為空函數。

3.2.3 os_cpu_a.s

μc/os-ⅱ移植的絕大部分工作都集中在os_cpu_a.s文件的移植上,在這個(gè)文件里,最困難的工作又集中體現在osintctxsw和ostickisr這兩個(gè)函數的實(shí)現上。這是因為這兩個(gè)函數的實(shí)現是和移植者的移植思路以及相關(guān)硬件定時(shí)器、中斷寄存器的設置有關(guān),在實(shí)際的移植工作中,這兩個(gè)地方也是比較容易出錯的地方,這部分需要對處理器的寄存器進(jìn)行操作,所以必須用匯編語(yǔ)言編寫(xiě),包括4個(gè)子函數:osstarthighrdy()、osctxsw()、osintctxsw()、ostickisr()。

osstarthighrdy()該函數首先調用鉤子函數ostaskswhook(),然后將osrunning標志位設置為真,表示任務(wù)開(kāi)始執行,從而保證任務(wù)切換操作的正確執行,緊接著(zhù)從具有最高優(yōu)先級的任務(wù)控制塊中取得任務(wù)的堆棧指針,初始化堆棧指針寄存器sp,然后恢復其他的寄存器,開(kāi)始執行最高優(yōu)先級的任務(wù)。

osctxsw()該函數在任務(wù)級任務(wù)切換函數中調用,首先保存處理器寄存器,將當前sp存入任務(wù)tcb中,載入就緒最高優(yōu)先級任務(wù)的sp,從新任務(wù)的任務(wù)堆棧中恢復處理器所有寄存器的值,然后執行中斷返回指令。

osintctxsw()該函數是在isr中執行任務(wù)切換功能,其原理基本上與任務(wù)級的切換相同,區別只是isr已經(jīng)保存了cpu的寄存器,因此不要再進(jìn)行類(lèi)似的操作,只需對堆棧指針作相應的調整即可。

ostickisr()該函數是系統時(shí)鐘節拍中斷服務(wù)函數,首先要保存處理器寄存器,接著(zhù)調用osintenter()函數,以保證中斷嵌套層數不超過(guò)255層,如果滿(mǎn)足了該條件,則把堆棧指針保存到當前任務(wù)的任務(wù)控制塊tcb中,然后給產(chǎn)生中斷的設備清中斷,重新允許中斷,接下來(lái)調用ostimetick()來(lái)維持μc/os-ⅱ內部的定時(shí)以及調用osintexit()函數決定是否因為這個(gè)中斷服務(wù)程序的執行,使得更高優(yōu)先級的任務(wù)就緒。

4 μc/os-ⅱ的測試

做完移植工作以后,就要測試移植是否正確,這其實(shí)是移植過(guò)程的最后一步,應該首先不加任何用代碼來(lái)測試移植好的μc/os-ⅱ,即應該首先測試內核自身的運行狀況,這樣做的目的是如果有些部分未能正常工作,那就是移植本身的問(wèn)題,而不是應用代碼產(chǎn)生的問(wèn)題,主要分為以下幾個(gè)步驟來(lái)進(jìn)行移植的測試:

首先,必須了解處理器所使用的編譯器系統,這個(gè)步驟取決于使用的編譯器,在這期間是無(wú)代碼的測試,其次,要驗證ostaskstkinit()和osstarthighrdy()函數,在os_cfg.h文件中設置os_task_stat_en為0,只讓一個(gè)空閑任務(wù)os_taskidle()運行,檢查是否出錯,然后需要驗證任務(wù)級切換osctxsw()函數,在測試任務(wù)tasktest()中加入ostimedly()函數,ostimedly()函數接著(zhù)調用os_sched(),os_sched()調用匯編語(yǔ)言編寫(xiě)的函數osctxsw()函數,如果是正確配置了swi,cpu就會(huì )開(kāi)始執行osctxsw(),最后,需要驗證osintctxsw()和ostickisr()函數。

當上述的這些測試步驟都成功后,可以嘗試運行一些具體的任務(wù),按照由簡(jiǎn)到繁的過(guò)程不斷使測試變得復雜,來(lái)進(jìn)一步驗證內核的穩定性和系統性能。

這里建立了一個(gè)簡(jiǎn)單的led燈閃爍控制任務(wù),其代碼如下:

加載后,led燈閃爍控制正常,則測試成功,內核正常運轉,若測試出現問(wèn)題,就要認真找出問(wèn)題所在,不可忽略硬件的問(wèn)題,還有編譯器等,當然也可以采用其他的測試,如串口的測試等。

5 結語(yǔ)

以上所述為μc/os-ⅱ在arm7上移植的通用方法,但針對不同的處理器還需要作適當的修改,rtos是當今嵌入式應用的熱點(diǎn),應用rtos,可以提高產(chǎn)品的可靠性,降低研發(fā)周期,其中μc/os-ⅱ具有很好的實(shí)時(shí)性和很小的代碼量,占用空間少,執行效率高,移植方法相對簡(jiǎn)單,因此掌握μc/os-ⅱ的移植方法是相當重要的。



關(guān)鍵詞:

評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>