ARM7內(nèi)核的中斷屏蔽方法
3.2 匯編語言程序?qū)崿F(xiàn)
C語言程序只能實現(xiàn)對向量中斷IRQ的屏蔽,具有局限性,如想實現(xiàn)對全部中斷的屏蔽就只能使用匯編語言來實現(xiàn)。程序如下:
在讀/寫CPSR時,可以指定傳送的區(qū)域,指定一種或多種(字母必須為小寫)格式:
◆_c為控制域屏蔽字節(jié)(CPSR[7…0]);
◆_x為擴展域屏蔽字節(jié)(CPSR[15…8]);
◆_s為狀態(tài)域屏蔽字節(jié)(CPSR[23…16]);
◆_f為標志域屏蔽字節(jié)(CPSR[31…24])。
在Disable()函數(shù)中,通過直接將當前程序狀態(tài)寄存器的I、F置位來屏蔽I、F中斷。ARM7內(nèi)核在響應中斷后將置位中斷禁止標志,中斷處理結(jié)束后再清零中斷禁止標志,這樣可避免出現(xiàn)不受控制的中斷嵌套,即ARM7內(nèi)核本質(zhì)上是不支持同級中斷嵌套的。所以在Enable()函數(shù)中,當ARM7內(nèi)核在處于不同的工作模式時,應采取不同的模式來分別處理。用戶或系統(tǒng)模式下,函數(shù)直接清零I、F位,允許向量和快速中斷;向量中斷模式下只清零F位,允許快速中斷;快速中斷模式下處理較為復雜,首先要判斷在進入快速中斷模式之前ARM7內(nèi)核的工作模式,通過讀取存儲程序狀態(tài)寄存器來判斷。若之前處于向量中斷工作模式,則函數(shù)不作任何處理,直接結(jié)束;若不是處于向量中斷工作模式,則只清零I位,允許向量中斷。
結(jié)語
本文介紹一種ARM7內(nèi)核的中斷屏蔽方法,并給出基于該方法的C語言源代碼和匯編語言源代碼。該段代碼已經(jīng)在筆者參與研制的火災報警控制器中得到成功應用,可以完全替代x86體系下DOS.H中定義的庫函數(shù)enable()和disable()的功能。本文引用地址:http://www.biyoush.com/article/150568.htm
評論