μC/OSII下的ARM7中斷過(guò)程分析及優(yōu)化方法
引言
本文引用地址:http://dyxdggzs.com/article/171563.htm目前,在嵌入式處理器芯片中,以ARM7為核心的處理器是應用較多的一種。它具有多種工作模式,并且支持兩種不同的指令集(標準32位ARM指令集和16位Thumb指令集)。μC/OSII是專(zhuān)為嵌入式應用設計的搶占式、多任務(wù)實(shí)時(shí)操作系統,可用于各類(lèi)8位、16位和32位單片機或DSP。μC/OSII向ARM7移植具有得天獨厚的優(yōu)點(diǎn),所以“μC/OSII+ARM7”成為廣泛應用的一款平臺。
不管是哪種型號的ARM處理器,也無(wú)論該嵌入式系統中是否有操作系統,在計算機與外界實(shí)時(shí)交互的過(guò)程中,中斷技術(shù)都是一項關(guān)鍵的技術(shù)。當外部事件發(fā)生時(shí),CPU必須及時(shí)響應中斷以實(shí)現對相應事件的處理,因此能否中斷嵌套是影響嵌入式系統實(shí)時(shí)性能的主要因素。
1 ARM7的中斷處理
ARM7處理器的中斷主要有兩種,本文主要討論IRQ中斷異常的響應機制。當中斷請求IRQ到來(lái)使CPU進(jìn)入中斷響應時(shí),CPU將會(huì )自動(dòng)完成下列工作:首先,將PC、CPSR的當前值存入中斷模式的LR、SPSR中;然后,操作CPSR中的運行狀態(tài)位,使CPU進(jìn)入中斷模式并關(guān)閉中斷;最后將PC的值改成0x00000018,從而使CPU的執行跳轉到IRQ中斷入口0x00000018處。異常向量表中的0x00000018處使用一條“LDR PC,[PC,#0xff0]”指令,在IRQ處使用的這條指令與其他向量不同。當CPU執行這條指令但還沒(méi)有跳轉時(shí),PC的值為0x00000020(因為ARM7TDMI內核是三級流水結構),0x00000020減去0x00000FF0為0xFFFFF030,這是VIC的特殊寄存器VICVectAddr的地址單元。這個(gè)寄存器保存當前將要服務(wù)的IRQ的中斷服務(wù)程序的入口,故讀取VICVectAddr寄存器的值,然后放入PC程序指針,即跳轉到相應中斷服務(wù)程序,從而使CPU開(kāi)始執行中斷服務(wù)程序。
2 Handler宏分析
“μC/OSII+ARM7”系統中,只使用了ARM7的IRQ中斷。由于不同的ARM芯片的中斷系統并不完全一樣,因此不可能編寫(xiě)出對所有使用ARM核的處理器通用的中斷及時(shí)鐘節拍移植代碼。但是,為了使用戶(hù)用C語(yǔ)言編寫(xiě)中斷服務(wù)程序時(shí)不必為處理器的硬件區別而困擾,這里根據μC/OSII對中斷服務(wù)程序的要求以及ARM7體系結構和ADS編譯器的特點(diǎn),編寫(xiě)了一個(gè)適用于所有基于A(yíng)RM7核處理器的匯編宏--Handler。這個(gè)宏實(shí)現了“μC/OSII+ ARM7”中斷服務(wù)程序的匯編語(yǔ)言代碼與C語(yǔ)言函數代碼之間的通用接口。其作用是對用戶(hù)的C語(yǔ)言中斷處理程序進(jìn)行包裝,只有通過(guò)這個(gè)包裝之后,系統才能執行用戶(hù)的中斷處理程序。
中斷服務(wù)程序流程如圖1所示。在進(jìn)入Handler宏中,首先保存LR、SPSR以及相關(guān)寄存器的值于中斷模式下的堆棧中,以便于斷點(diǎn)恢復。然后使記錄系統中斷次數的全局變量OSIntNeSTing加1并關(guān)中斷切換到系統模式,調用C語(yǔ)言中斷處理程序。在執行完中斷處理程序后,調用出中斷函數,以獲取最高優(yōu)先級就緒任務(wù)的任務(wù)控制塊指針和任務(wù)優(yōu)先級。返回中斷模式后,通過(guò)比較當前任務(wù)與待切換任務(wù)的優(yōu)先級,判斷是否進(jìn)行任務(wù)切換,最后返回斷點(diǎn)。
圖1 中斷服務(wù)程序流程
IRQ異常處理代碼的匯編部分--Handler宏:
MACRO
$IRQ_Label HANDLER $IRQ_ExcepTION_Function
EXPORT $IRQ_Label;輸出的標號
IMPORT $IRQ_Exception_Function;引用的外部標號
$IRQ_Label
SUB LR, LR, #4;計算返回地址
STMFD SP!, {R0R3, R12, LR};保存任務(wù)環(huán)境
MRS R3, SPSR;保存狀態(tài)
STMFD SP, {R3,SP,LR}^;保存用戶(hù)狀態(tài)的R3、SP、LR
;OSIntNesting++
LDR R2,=OSIntNesting
LDRB R1, [R2]
ADD R1, R1, #1
STRB R1, [R2]
SUB SP, SP, #4*3
MSR CPSR_c, #(NoInt | SYS32Mode)
;切換到系統模式以便對相關(guān)寄存器進(jìn)行操作
CMP R1, #1
LDREQ SP, =StackUsr
;在第1次中斷時(shí)就重新開(kāi)辟一個(gè)專(zhuān)門(mén)存儲中斷中用到的變量以避免存儲空間的沖突
BL $IRQ_Exception_Function ;調用C語(yǔ)言的中斷處理程序
MSR CPSR_c, #(NoInt | SYS32Mode);切換到系統模式
LDR R2, =OsEnterSum
;OsEnterSum,使OSIntExit退出時(shí)中斷關(guān)閉
MOV R1, #1
STR R1, [R2]
BL OSIntExit
;獲取最高優(yōu)先級就緒任務(wù)的任務(wù)控制塊指針和優(yōu)先級
評論