大家都知道,ARM有IRQ, FIQ, USR,SVC,ABORT等各種模式。當系統收到IRQ的時候,會進入ARM的IRQ模式。那么,ARM Linux各種驅動的中斷服務程序工作在ARM的IRQ模式嗎?
答案是否定的。
我們加一段匯編來讀CPSR:

然后我們隨便找一個ARM Linux的中斷服務程序去打印CPSR:

然后我們發現打印出來的值是:
cpsr:40000193
低8位的二進制是10010011
那么對應ARM CPSR的查詢,可以看出CPU處于ARM的SVC模式(低5位是10011),而且I bit被設置(第7位是1),所以是禁止IRQ的。

模式表:

可見,ARM Linux最初進入IRQ模式后,比較快速地從IRQ模式切換到了SVC模式,但是這個時候,并沒有使能CPSR的I bit,所以仍然是禁止其他中斷嵌套進入的。
(完)
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
ARM
+關注
關注
135文章
9553瀏覽量
391859 -
Linux
+關注
關注
88文章
11759瀏覽量
219013 -
中斷服務
+關注
關注
0文章
9瀏覽量
7086
原文標題:ARM Linux的中斷服務程序工作在ARM的IRQ模式嗎?
文章出處:【微信號:LinuxDev,微信公眾號:Linux閱碼場】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
熱點推薦
ARM中斷模式(IRQ)和快速中斷模式(FIQ)區別比較
IRQ高。 4、FIQ模式下,比IRQ模式多了幾個獨立的寄存器。 不要小看這幾個寄存器,ARM在編譯的時候,如果你FIQ
發表于 10-13 10:43
ARM的2種工作狀態和7種工作模式。[附帶文檔下載]
模式下的其他6中模式,有SVC,FIQ,IRQ,ABT,UND,SYS 都可以修改CPSR寄存器、從而控制ARM工作
發表于 08-20 09:14
基于ARM架構的linux中斷的工作原理是什么
最近在看一些關于arm linux中斷方面的資料,看了很多資料,總結一下自己對linux下中斷的理解,寫到這里供大家參考,以下所有的描述都是
發表于 05-30 09:23
ARM7和ARM-Cortex的區別,ARM為什么會有兩種啟動方式?
IRQ,FIQ定義: 這就是個普通中斷,當我們程序定義了該中斷,并且在程序運行的時候產生了
ARM中斷原理以及中斷嵌套
我們可以假設ARM核心有兩根中斷引腳(實際上是看不見的),一根叫 irq pin, 一根叫fiq pin。在ARM的cpsr中,有一個I位和
ARM Linux各種驅動的中斷服務程序工作在ARM的IRQ模式嗎?
評論