μC/OS-II在LPC213X上的多種移植方案
1 與μC/OS-II移植工作相關(guān)的主要特性
ARM體系結構分為7種運行模式,ARM和Thumb兩種工作狀態(tài)。LPC213X的編程模型就是標準的ARM7體系結構;同時(shí)LPC213X也具備ARM的標準異常模式IRQ和FIQ。稍具特色的是其VIC向量中斷控制器。分別對IRQ、FIQ、非向量中斷和軟件中斷進(jìn)行了分類(lèi),具有對32個(gè)中斷輸入的可編程分配機制。這對于μC/OS-II的移植至關(guān)重要。
芯片內部的RTC實(shí)時(shí)時(shí)鐘可由獨立的32 MHz晶振或基于VPB時(shí)鐘的可編程預分頻提供,作為實(shí)時(shí)系統的時(shí)鐘節拍來(lái)源。
2 μC/OS-II移植的主要工作
移植工作分為編譯器相關(guān)和處理器相關(guān)兩部分。前者主要涉及數據類(lèi)型定義、代碼格式、頭文件組織、條件編譯選項及混合編程等;后者主要涉及開(kāi)關(guān)中斷、堆棧方向、任務(wù)棧結構初始化、任務(wù)調度、中斷控制和響應、時(shí)鐘節拍處理和高優(yōu)先級任務(wù)執行等。
主要是編寫(xiě)3個(gè)文件:OS_CPU.H、OS_CPU_C.C和OS_CPU_A.S。其中l主要包含以下幾個(gè)重要函數;OSTaskStkInit()、OSStartHighRdy()、OSCtxSw()、OS-IntCtxSw()和OSTickISR()等。另外,還須編寫(xiě)配置文件、引導及初始化代碼和調試等。
3 兩個(gè)可行的移植方案
針對ARM所具有的7種不同運行模式,移植μC/OS-II系統時(shí)采用的處理器模式方案是多樣的。例如,可以讓系統運行在SVC管理模式,SWI軟中斷也用SVC模式,其他為異常模式;也可以使μC/OS-II運行在SYS系統模式;還可以使μC/OS-Il運行于用戶(hù)模式,任務(wù)或中斷切換時(shí)將其從SVC模式或IRQ、FlQ模式切換到SYS模式處理堆棧。在此形成以下兩種方案,并結合移植過(guò)程進(jìn)行簡(jiǎn)要分析。
方案一:系統運行于SVC管理模式,異常運行于異常模式。
①開(kāi)關(guān)中斷。設置這種方案中OS_CRITICAL_METHOD為3,則開(kāi)中斷過(guò)程為先保存CPSR寄存器值到RO,通過(guò)設置CPSR6、CPSR7兩位禁止FIQ和IRQ,關(guān)中斷則恢復原先開(kāi)中斷時(shí)保存在R0中的CPSR。
②任務(wù)切換。因為非異常任務(wù)都運行在SVC模式,所以任務(wù)切換要做的只是保存舊任務(wù)的寄存器狀態(tài)到堆棧,并且恢復新任務(wù)的堆棧狀態(tài)到寄存器當中,相關(guān)函數為OSCtxSw()。要注意在這里上下文切換中無(wú)須對SPSR負責,因為SPSR是備份CPSR寄存器,只有當模式切換從FIQ、IRQ模式退出時(shí)才發(fā)生作用。換句話(huà)講,SPSR總是在中斷禁止時(shí)才發(fā)生作用。
③中斷級任務(wù)切換和相應中斷機制。中斷異常分為FIQ和IRQ異常。IRQ的中斷級任務(wù)切換過(guò)程O(píng)S_CPU_IRQ_ISR()如圖1所示。
由圖1可知,該函數作為μC/OS-II系統的中斷調度函數,進(jìn)入中斷IRQ模式后立即返回SVC模式保存原先任務(wù)狀態(tài);再回到IRQ執行用戶(hù)級中斷處理代碼OS_CPU_IRQ_ISR_Handler();完成后返回SVC模式運行最高優(yōu)先級任務(wù)。

LPC213X具有VIC向量中斷控制器,把所有中斷分為FIQ、向最中斷和非向量中斷。FIQ從中斷向量表處開(kāi)始處理程序,直接在用戶(hù)中斷處理代碼OS_CPU_FTQ_ISR_Handler()里調用中斷處理程序;而向量中斷IRQ在響應時(shí)會(huì )在VICVectAddr(0xFFFFF030)寄存器上出現該中斷處理程序的首地址。所以作為μC/OS-II的IRQ的用戶(hù)中斷處理代碼,必須進(jìn)行如下處理:

?、苤袛嘞蛄勘?。在該方案的中斷向量表中,FIQ和IRQ中斷向量填寫(xiě)的是程序跳轉指令。其中FIQ跳到OS_CPU_FIQ_ISR(),IRQ跳到OS_CPU_IRQ_ISR()。
⑤時(shí)鐘節拍的產(chǎn)生。μC/OS-II時(shí)鐘節拍需要lO~100ms一次的精確間隔。LPC213X使用11 MHz的外部晶振,外設時(shí)鐘與系統時(shí)鐘頻分比設為l,而RTC設置外設時(shí)鐘為時(shí)鐘源,然后把Timer0作為向量中斷IRQ,編寫(xiě)時(shí)鐘中斷處理程序實(shí)現時(shí)鐘節拍。

方案二:系統運行于SYS系統模式,異常服務(wù)程序處理在SYS系統模式下執行,軟中斷處理在管理模式下執行。
①開(kāi)關(guān)中斷。該方案下OS_CRITICAL_METHOD為2,具體過(guò)程不直接從匯編代碼實(shí)現,而是通過(guò)軟件中斷SWI系統服務(wù)來(lái)實(shí)現。開(kāi)關(guān)中斷在SVC管理模式下進(jìn)行,因為ARM決定CPSR可以在任意模式下被訪(fǎng)問(wèn)。
②任務(wù)切換。任務(wù)切換包括任務(wù)級調度切換和中斷處理程序調度切換。任務(wù)級切換采用軟中斷SWI方式實(shí)現,需要注意的是此時(shí)SWI中斷處理程序并不返回,所以每次SWI中斷一開(kāi)始就重新初始化SVC管理模式的堆棧地址空間,否則會(huì )造成內存泄漏或溢出。其流程如圖2所示。

圖2中,第一步為軟件中斷通用處理過(guò)程,是每一個(gè)軟件中斷都必須運行的代碼;而后幾步為任務(wù)調度所要做的代碼,具體調度由OSCtxSw實(shí)現上下文切換。整體利用宏OS_TASK_SW()實(shí)現,在OS_CPU.H中定義該宏為軟中斷,并分配中斷號0。
③中斷級任務(wù)切換。根據LPC213X處理器的VIC控制特點(diǎn),采用前后臺系統的傳統處理方法進(jìn)行中斷處理程序調用,只是每個(gè)中斷處理程序都加上相同的任務(wù)上下文切換相關(guān)代碼,這些代碼采用宏匯編的方法實(shí)現。具體流程如圖3所示。從圖中可以看出,保存上下文和恢復就緒任務(wù)都是在IRQ模式下進(jìn)行的,而用戶(hù)級處理程序在SYS模式下進(jìn)行的,與前一種方案剛好相反。但是,這樣設計中斷調度并利用宏匯編實(shí)現使得當系統中斷處理調用較多時(shí)重復代碼量增加。

④中斷向量表。在該方案的中斷向量表中,FIQ和IRQ等中斷向量填寫(xiě)的是宏匯編函數相對應的中斷處理服務(wù)程序的名字,不作特殊處理。
⑤時(shí)鐘節拍的產(chǎn)生。該方案的時(shí)鐘節拍與前一方案的產(chǎn)生方法相同。
4 系統啟動(dòng)和引導過(guò)程
除了以上這些移植代碼,系統啟動(dòng)還有很多工作要做,其流程如圖4所示。

圖4中中斷向量表的配置要根據以上兩種方案分別做工作,而初始化模式堆棧則是不同模式都必須完成的工作。用戶(hù)級的初始化代碼可以寫(xiě)在外圍設備初始化中。
5 移植代碼調試過(guò)程
多任務(wù)系統移植代碼調試有時(shí)不能單步調試,時(shí)鐘節拍的引入令系統比前后臺系統復雜得多,所以要有好的調試方法??梢圆捎靡韵抡{試步驟:
①關(guān)閉時(shí)鐘節拍,即關(guān)閉時(shí)鐘中斷單步調試,看系統會(huì )不會(huì )進(jìn)入Taskldle任務(wù);
②關(guān)閉時(shí)鐘節拍,同時(shí)分別調試FIQ和IRQ中斷代碼;
③開(kāi)時(shí)鐘節拍,單獨調試時(shí)鐘中斷ISR;
④編寫(xiě)簡(jiǎn)單的多任務(wù)程序(1個(gè)或2個(gè)),同時(shí)在每一個(gè)任務(wù)中調用OSTimaDly(1)函數,查看具體的進(jìn)程調度過(guò)程。(多種方案的移植代碼見(jiàn)本刊網(wǎng)站www.mesnet.com.cn——編者注)
6 總 結
在各種系統的移植過(guò)程中發(fā)生問(wèn)題最多的是內存泄赫,這常常導致芯片發(fā)生代碼預取或數據中止異常。對應用系統來(lái)說(shuō),應該對這類(lèi)中止異常做相應的提示。
μC/OS-II移植綜合性較強,在移植前必須領(lǐng)會(huì )多任務(wù)切換原理和系統內核結構,熟悉ARM匯編語(yǔ)言和編程模型,了解啟動(dòng)代碼內容、編譯器及芯片中斷系統等。該丁作看似簡(jiǎn)單但其實(shí)內容豐富,需要較全面的軟硬件知識。
本文給出的兩種移植方案切實(shí)可行,運行效率較高,在其他ARM7TDMI核的芯片上做小改動(dòng)后也可以應用;同時(shí),對其他嵌入式系統在不帶MMU內存管理模塊處理器上的移植也有很好的參考價(jià)值。免費提供本文相關(guān)代碼,請聯(lián)系wlazhenqian@hotmail.com。
評論