程序狀態(tài)寄存器和操作指令
在ARM Architecture Reference Manual手冊(cè)中,ProgrammersModel的目錄下,有Registers子目錄
我們介紹CPSR和SPSR
CPSR:Current Program Status Register
SPSR:Saved Program Status Register
CPSR:cpsr在用戶級(jí)編程時(shí)用于存儲(chǔ)條件碼;CPSR包含條件碼標(biāo)志,中斷禁止位,當(dāng)前處理器模式以及其他狀態(tài)和控制信息。
本文引用地址:http://cafeforensic.com/article/201611/321997.htmSPSR:程序狀態(tài)保存寄存器,用于保存CPSR的狀態(tài),以便異常返回后恢復(fù)異常發(fā)生時(shí)的工作狀態(tài)。
對(duì)于CPSR只有1個(gè),對(duì)于SPSR有5個(gè)(Supervisor/abort/Undefined/interrupt/Fast各有1個(gè)):
CPSR 寄存器(和保存它的 SPSR 寄存器)中的位分配如下:
31 30 29 28 --- 7 6 - 4 3 2 1 0 N Z C V I F M4 M3 M2 M1 M0 0 0 0 0 0 User26 模式 0 0 0 0 1 FIQ26 模式 0 0 0 1 0 IRQ26 模式 0 0 0 1 1 SVC26 模式 1 0 0 0 0 User 模式 1 0 0 0 1 FIQ 模式 1 0 0 1 0 IRQ 模式 1 0 0 1 1 SVC 模式(設(shè)定CPU到SVC32模式) 1 0 1 1 1 ABT 模式 1 1 0 1 1 UND 模式 CPSR和SPSR的操作指令:mrs,msr
MRS
功能:將狀態(tài)寄存器的內(nèi)容傳送至通用寄存器。
指令的格式為:MRS{<條件碼>}Rd,CPSR}SPSR其中:Rd目標(biāo)寄存器,Rd不允許R15。R=0 將CPSR中的內(nèi)容傳送目的寄存器。R=1 將SPSR中的內(nèi)容傳送至目的寄存器。注釋:MRS與MSR配合使用,作為更新PSR的讀-修改-寫序列的一部分。例如:改變處理器或清除標(biāo)志Q。注意:當(dāng)處理器在用戶模式或系統(tǒng)模式下,一定不能試圖訪問SPSR這條指令不影響條件碼標(biāo)志。例:MRS R0,CRSR ;將CPSR中的內(nèi)容傳送至R0MRS R3,SPSR ;將SPSR中的內(nèi)容傳送至R3
MSR
指令的格式為:
MSR{條件} 程序狀態(tài)寄存器(CPSR或SPSR)_<域>,操作數(shù)
功能:
MSR指令用于將操作數(shù)的內(nèi)容傳送到程序狀態(tài)寄存器的特定域中。其中,操作數(shù)可以為通用寄存器或立即數(shù)。<域>用于設(shè)置程序狀態(tài)寄存器中需要操作的位,32位的程序狀態(tài)寄存器可分為4個(gè)域:
位[31:24]為條件標(biāo)志位域,用f表示;
位[23:16]為狀態(tài)位域,用s表示;
位[15:8]為擴(kuò)展位域,用x表示;
位[7:0]為控制位域,用c表示;
該指令通常用于恢復(fù)或改變程序狀態(tài)寄存器的內(nèi)容,在使用時(shí),一般要在MSR指令中指明將要操作的域。
指令示例:
MSR CPSR,R0 ;傳送R0的內(nèi)容到CPSR
MSR SPSR,R0 ;傳送R0的內(nèi)容到SPSR
MSR CPSR_c,R0 ;傳送R0的內(nèi)容到CPSR,但僅僅修改CPSR中的控制位域
評(píng)論