引言
如今,在嵌入式處理器芯片中,以ARM7為核心的處理器是應用較多的一種。它具有多種工作模式,并且支持兩種不同的指令集(標準32位ARM指令集和16位Thumb指令集)。μC/OSII是專為嵌入式應用設計的搶占式、多任務實時操作系統,可用于各類8位、16位和32位單片機或DSP。μC/OSII向ARM7移植具有得天獨厚的優點,因此,“μC/OSII+ARM7”成為廣泛應用的一款平臺。
不管是哪種型號的ARM處理器,也無論該嵌入式系統中是否有操作系統,在計算機與外界實時交互的過程中,中斷技術都是一項關鍵的技術。當外部事件發生時,CPU必須及時響應中斷以實現對相應事件的處理,因此能否中斷嵌套是影響嵌入式系統實時性能的主要因素。
1 ARM7的中斷處理
ARM7處理器的中斷主要有兩種,本文主要討論IRQ中斷異常的響應機制。當中斷請求IRQ到來使CPU進入中斷響應時,CPU將會自動完成下列工作:首先,將PC、CPSR的當前值存入中斷模式的LR、SPSR中;然后,操作CPSR中的運行狀態位,使CPU進入中斷模式并關閉中斷;最后將PC的值改成0x00000018,從而使CPU的執行跳轉到IRQ中斷入口0x00000018處。異常向量表中的0x00000018處使用一條“LDR PC,[PC,#0xff0]”指令,在IRQ處使用的這條指令與其他向量不同。當CPU執行這條指令但還沒有跳轉時,PC的值為0x00000020(因為ARM7TDMI內核是三級流水結構),0x00000020減去0x00000FF0為0xFFFFF030,這是VIC的特殊寄存器VICVectAddr的地址單元。這個寄存器保存當前將要服務的IRQ的中斷服務程序的入口,故讀取VICVectAddr寄存器的值,然后放入PC程序指針,即跳轉到相應中斷服務程序,從而使CPU開始執行中斷服務程序。
2 Handler宏分析
“μC/OSII+ARM7”系統中,只使用了ARM7的IRQ中斷。由于不同的ARM芯片的中斷系統并不完全一樣,因此不可能編寫出對所有使用ARM核的處理器通用的中斷及時鐘節拍移植代碼。但是,為了使用戶用C語言編寫中斷服務程序時不必為處理器的硬件區別而困擾,這里根據μC/OSII對中斷服務程序的要求以及ARM7體系結構和ADS編譯器的特點,編寫了一個適用于所有基于ARM7核處理器的匯編宏--Handler。這個宏實現了“μC/OSII+ ARM7”中斷服務程序的匯編語言代碼與C語言函數代碼之間的通用接口。其作用是對用戶的C語言中斷處理程序進行包裝,只有通過這個包裝之后,系統才能執行用戶的中斷處理程序。
中斷服務程序流程如圖1所示。在進入Handler宏中,首先保存LR、SPSR以及相關寄存器的值于中斷模式下的堆棧中,以便于斷點恢復。然后使記錄系統中斷次數的全局變量OSIntNeSTing加1并關中斷切換到系統模式,調用C語言中斷處理程序。在執行完中斷處理程序后,調用出中斷函數,以獲取最高優先級就緒任務的任務控制塊指針和任務優先級。返回中斷模式后,通過比較當前任務與待切換任務的優先級,判斷是否進行任務切換,最后返回斷點。
圖1 中斷服務程序流程
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};保存任務環境
MRS R3, SPSR;保存狀態
STMFD SP, {R3,SP,LR}^;保存用戶狀態的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)
;切換到系統模式以便對相關寄存器進行操作
CMP R1, #1
LDREQ SP, =StackUsr
;在第1次中斷時就重新開辟一個專門存儲中斷中用到的變量以避免存儲空間的沖突
BL $IRQ_Exception_Function ;調用C語言的中斷處理程序
MSR CPSR_c, #(NoInt | SYS32Mode);切換到系統模式
LDR R2, =OsEnterSum
;OsEnterSum,使OSIntExit退出時中斷關閉
MOV R1, #1
STR R1, [R2]
BL OSIntExit
LDR R2, =OsEnterSum
;中斷服務程序要退出,所以OsEnterSum=0
MOV R1, #0
STR R1, [R2]
MSR CPSR_c, #(NoInt | IRQ32Mode) ;切換回中斷模式
LDMFD SP, {R3, SP, LR}^ ;恢復用戶狀態的R3、SP、LR
LDR R0, =OSTCBHighRdy
LDR R0, [R0]
LDR R1, =OSTCBCur
LDR R1, [R1]
CMP R0, R1
ADD SP, SP, #4*3
MSR SPSR_cxsf, R3
LDMEQFD SP!, {R0R3, R12, PC}^ ;不進行任務切換
LDR PC, =OSINTCtxSw;進行任務切換
MEND
END
通過對Handler宏的分析可知,用戶的C語言中斷處理程序是在特權模式--系統模式下運行的,并且CPU在執行中斷服務程序時中斷都是關閉的,所以本系統采用的是最為簡單的非嵌套中斷方式。這種方式的優點是,上下文數據不會被任何順序的中斷所破壞;缺點是,在中斷服務程序執行時不能根據中斷優先級進行中斷嵌套,延時時間長,只有當一個ISR完全結束并退出中斷后才重新接受中斷,降低了系統的實時特性。為提高系統的實時性,需要對其中斷進行優化。
3 中斷的優化
改寫μC/OSII 內核中 HANDLER 宏可以實現ARM的中斷嵌套,這樣做雖然提高了系統的實時性,但損害了系統運行的穩定性和可移植性。通過對中斷過程的分析,下面給出一種編寫中斷服務程序的模板,充分利用ISR執行在特權模式--系統模式這一特點來實現中斷嵌套的條件。中斷服務程序模板如下:
void ISR(void){
OS_ENTER_CRITICAL();//在中斷服務程序中關中斷清中斷標志;//防止沒有清中斷標志使得中斷多次進入關閉低優先級;//禁止低優先級中斷
S_EXIT_CRITICAL();//在中斷服務程序中開中斷用戶的C語言代碼;//進行用戶在中斷中要做的工作
VICVectAddr=0;//將中斷服務程序的入口地址置0
}
由于Handler宏中已將LR、SPSR、返回地址和發生中斷前的堆棧指針等寄存器入棧保存,所以接下來要做的就只剩下開關中斷的工作。由于在進入C中斷處理程序之前進入的是關中斷系統模式,所以必須在C語言中重新打開中斷,而C語言是不能進行寄存器操作的,因此必須調用軟中斷OS_EXIT_CRITICAL()重新打開中斷。在開中斷之前,要判斷將全局變量OsEnterSum減1后是否為0,所以必須在調用開中斷之前調用軟中斷OS_ENTER_CRITICAL()將OsEnterSum變成1。在臨界區中可以進行一些處理,如清中斷標志、關低優先級中斷等。進行C語言中斷服務程序之后要將VICVectAddr置位為0,這是ARM7處理器核的要求必須進行這樣的編寫,否則會導致一些錯誤(如不能第2次進入中斷等)。
結語
“μC/OSII+ ARM7”是當前嵌入式系統中廣泛應用的一款平臺,適合于復雜度不是很高的中小型嵌入式系統。本文在深入分析”μC/OSII+ ARM7”中斷機制的基礎上,對IRQ中斷響應機制進行了改進,提出了優化方案。實驗證明,此方法可以實現中斷的嵌套并且提高系統實時性,具有一定的應用價值。
上一篇:基于ARM的數字調壓控制系統設計詳解
下一篇:ARM S3C4510B系統中異常中斷的功能及特點
推薦閱讀
史海拾趣
面對工業應用領域的特殊需求,ATP敏銳地捕捉到了市場機遇。公司成功推出了業界首款工業級SLC e.MMC產品E800Pi,這款產品以其高達6萬次的單元擦寫耐久性和出色的耐高溫、交叉溫度能力,受到了工業領域的廣泛認可。E800Pi的推出,不僅拓寬了ATP的產品線,也進一步提升了公司在工業存儲解決方案領域的市場地位。
隨著公司業務的不斷發展,AMP公司意識到與國際伙伴合作的重要性。于是,公司積極尋求與國際知名企業的戰略合作,通過技術交流和資源共享,共同開發新型電子產品。這些國際合作不僅提升了AMP公司的技術水平,還進一步提升了其品牌影響力和國際知名度。公司因此獲得了更多海外市場的認可,實現了業務的全球化布局。
隨著全球電子市場的不斷擴大,CW Industries也積極拓展其國際業務。公司通過參加各種國際電子展會和交流活動,與全球各地的客戶和合作伙伴建立了廣泛的聯系。這不僅為公司帶來了更多的商機,還使得CW Industries能夠及時了解國際市場的最新動態和技術趨勢。通過這些國際交流活動,CW Industries不斷提升其品牌影響力和市場競爭力。
在競爭激烈的電子行業中,品牌形象對于企業的成功至關重要。Facon深知這一點,因此他們始終注重品牌塑造和形象維護。通過舉辦技術研討會、參加行業展會等方式,Facon不斷向外界展示自己的技術實力和產品優勢。同時,他們還積極參與公益活動和社會責任項目,提升企業的社會形象。這些努力讓Facon在消費者和合作伙伴中樹立了良好的品牌形象。
品質是電子行業的生命線。Diconex公司深知品質的重要性,因此從原材料采購到生產制造的每一個環節都嚴格把控品質。公司建立了完善的質量管理體系,對每一道生產工序都進行嚴格的檢測和評估。這種對品質的執著追求使得Diconex的產品在市場上具有很高的口碑和競爭力。
面對日益激烈的市場競爭,APX Technologies積極尋求與其他企業的合作。公司與一家知名的電子設備制造商達成戰略合作協議,共同開發一款具有創新功能的新型智能手機。這款手機的成功上市不僅提升了APX Technologies的品牌知名度,也為其帶來了可觀的利潤。
來源 移動3G網 www.Goes3G.com/在今天的都市生活中,手機的普及程度已遠遠超過了電腦,用手機上網也正在迅速興旺起來。所不同的是,電腦上網主要采用的是HTTP協議,而手機上網則是以WAP協議為主。 WAP是WIRELESSAPPLICATION PROTOC0L ...… 查看全部問答∨ |
|
臺灣笙科電子AMIC的A7105 是一低成本適用于2.4G 無線 數據通信的收發IC,內含高靈敏度接收 器(-99dBm@250KBPS)及高效功率 放大器,很適合10-40米之內的無線 通信應用 。 A7105的相關參數可通過3/4線SPI設置,最大64字節FIFO,支持CRC(16CRR ...… 查看全部問答∨ |
windows mobile開發 因為要添加mass_storage_class驅動,要用到usbmsfn.dll文件 在release目錄下是有這個文件的,但不知該文件從何而來。 msdn上講mass storage的樣例文件是在I:\\wm604\\PUBLIC\\COMMON\\OAK\\DRIVERS\\USBFN\\CLASS\\STORAGE中 ...… 查看全部問答∨ |
本人非計算機專業出身,從事嵌入式應用層軟件開發,對軟件開發個人覺的國內學C、C++、JAVA等很多,主要是由于這些方面的資料較多,可以通過自己的努力成才。而底層的驅動開發、linux等由于各種條件的局限,或者說國內的精英貢獻的資料太少--譬如 ...… 查看全部問答∨ |
|
專業是電子信息科學與技術 數電模電,C/C++/匯編都學了。 數電模電學校教得很淺 C/C++/匯編自以為相對于其他同學學得不錯 畢業了想搞單片機或者嵌入式 但是不知道怎么入門,現在就一直在深入學習C,和c++ 所以請各位前輩給點意見 比如說該看 ...… 查看全部問答∨ |
程序理論上永遠保持。 S7-200系統提供了EEPROM:非易失的電可擦除存儲器,保存數據不需要供電,并且可以改寫其內容。用戶程序也永久保存在程序EEPROM區中。… 查看全部問答∨ |
Zynq™-7000 EPP 是一種新型產品,它將工業標準的 ARM® 雙核 Cortex™-A9 MPCore™ 處理系統與 Xilinx 統一的 28nm 可編程邏輯FPGA完美地結合在一起。面向處理器的體系結構實現了一個全面的處理平臺,為開發人員提供 ASIC 級的 ...… 查看全部問答∨ |