arm-CPSR暫存器
阿新 • • 發佈:2021-12-01
轉:https://www.cnblogs.com/armlinux/archive/2011/03/23/2396833.html
31 | 30 | 29 | 28 | 27 | ~ | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |||
N | Z | C | V | 保留 | I | F | T | M4 | M3 | M2 | M1 | M0 | |||||
N | Negative/Less Than | I | IRQ disable | ||||||||||||||
Z | Zero | F | FIQ disable | ||||||||||||||
C | Carry/Borrow/Extend | T | State bit | ||||||||||||||
V | Overflow | M0~4 | Mode bits |
1、條件碼標誌
N、Z、C、V均為條件碼標誌位。它們的內容可被算術或邏輯運算的結果所改變,並且可以決定某條指令是否被執行。條件碼標誌各位的具體含義如下表所示:
標誌位 | 含義 |
N | 當用兩個補碼錶示的帶符號數進行運算時,N=1表示運算的結果為負數;N=0表示運算的結果為正數或零 |
Z | Z=1表示運算的結果為零,Z=0表示運算的結果非零。 |
C | 可以有4種方法設定C的值: |
-加法運算(包括CMP):當運算結果產生了進位時(無符號數溢位),C=1,否則C=0。 | |
-減法運算(包括CMP):當運算時產生了借位時(無符號數溢位),C=0,否則C=1。 | |
-對於包含移位操作的非加/減運算指令,C為移出值的最後一位。 | |
-對於其它的非加/減運算指令,C的值通常不會改變。 | |
V | 可以有2種方法設定V的值: |
-對於加減法運算指令,當運算元和運算結果為二進位制的補碼錶示的帶符號數時,V=1表示符號位溢位 | |
-對於其它的非加/減運算指令,V的值通常不會改變。 | |
Q | 在ARM V5及以上版本的E系列處理器中,用Q標誌位指示增強的DSP運算指令是否發生了溢位。在其它版本的處理器中,Q標誌位無定義 |
在ARM狀態下,絕大多數的指令都是有條件執行的;在THUMB狀態下,僅有分支指令是條件執行的。
2 控制位
CPSR的低8位(包括I、F、T和M[4:0])稱為控制位,當發生異常時這些位可以被改變。如果處理器運行於特權模式時,這些位也可以由程式修改。
·中斷禁止位I、F:置1時,禁止IRQ中斷和FIQ中斷。
·T標誌位:該位反映處理器的執行狀態。當該位為1時,程式運行於THUMB狀態,否則運行於ARM狀態。該訊號反映在外部引腳TBIT上。在程式中不得修改CPSR中的TBIT位,否則處理器工作狀態不能確定。
·執行模式位M[4:0]:這幾位是模式位,這些位決定了處理器的執行模式。具體含義如下表所示:
·保留位:CPSR中的其餘位為保留位,當改變CPSR中的條件碼標誌位或者控制位時,保留位不要改變,在程式中也不要用保留位儲存資料。保留位將用於ARM版本的擴充套件。
M[4:0] | 處理器模式 | ARM模式可訪問的暫存器 | THUMB模式可訪問的暫存器 |
0b10000 | 使用者模式 | PC,CPSR,R0~R14 | PC,CPSR,R0~R7,LR,SP |
0b10001 | FIQ模式 | PC,CPSR,SPSR_fiq,R14_fiq~R8_fiq,R0~R7 | PC,CPSR,SPSR_fiq,LR_fiq,SP_fiq,R0~R7 |
0b10010 | IRQ模式 | PC,CPSR,SPSR_irq,R14_irq~R13_irq,R0~R12 | PC,CPSR,SPSR_irq,LR_irq,SP_irq,R0~R7 |
0b10011 | 管理模式 | PC,CPSR,SPSR_svc,R14_svc~R13_svc,R0~R12 | PC,CPSR,SPSR_svc,LR_svc,SP_svc,R0~R7 |
0b10111 | 中止模式 | PC,CPSR,SPSR_abt,R14_abt~R13_abt,R0~R12 | PC,CPSR,SPSR_abt,LR_abt,SP_abt,R0~R7 |
0b11011 | 未定義模式 | PC,CPSR,SPSR_und,R14_und~R13_und,R0~R12 | PC,CPSR,SPSR_und,LR_und,SP_und,R0~R7 |
0b11111 | 系統模式 | PC,CPSR,R0~R14 | PC,CPSR,LR,SP,R0~R74 |