<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > 程序狀態(tài)寄存器和操作指令

程序狀態(tài)寄存器和操作指令

作者: 時(shí)間:2016-11-26 來(lái)源:網(wǎng)絡(luò ) 收藏
ARM中有個(gè)極其重要的寄存器,就是程序狀態(tài)寄存器
在A(yíng)RM Architecture Reference Manual手冊中,ProgrammersModel的目錄下,有Registers子目錄
我們介紹CPSR和SPSR

CPSR:Current Program Status Register
SPSR:Saved Program Status Register

CPSR:cpsr在用戶(hù)級編程時(shí)用于存儲條件碼;CPSR包含條件碼標志,中斷禁止位,當前處理器模式以及其他狀態(tài)和控制信息。

本文引用地址:http://dyxdggzs.com/article/201611/321997.htm
SPSR:程序狀態(tài)保存寄存器,用于保存CPSR的狀態(tài),以便異常返回后恢復異常發(fā)生時(shí)的工作狀態(tài)。
對于CPSR只有1個(gè),對于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 模式(設定CPU到SVC32模式) 1 0 1 1 1 ABT 模式 1 1 0 1 1 UND 模式 CPSR和SPSR的操作指令:mrs,msr
MRS
功能:將狀態(tài)寄存器的內容傳送至通用寄存器。
指令的格式為:MRS{<條件碼>}Rd,CPSR}SPSR其中:Rd目標寄存器,Rd不允許R15。R=0將CPSR中的內容傳送目的寄存器。R=1將SPSR中的內容傳送至目的寄存器。注釋?zhuān)篗RS與MSR配合使用,作為更新PSR的讀-修改-寫(xiě)序列的一部分。例如:改變處理器或清除標志Q。注意:當處理器在用戶(hù)模式或系統模式下,一定不能試圖訪(fǎng)問(wèn)SPSR這條指令不影響條件碼標志。例:MRSR0,CRSR;將CPSR中的內容傳送至R0MRSR3,SPSR;將SPSR中的內容傳送至R3
MSR
指令的格式為:
MSR{條件} 程序狀態(tài)寄存器(CPSR或SPSR)_<域>,操作數
功能:
MSR指令用于將操作數的內容傳送到程序狀態(tài)寄存器的特定域中。其中,操作數可以為通用寄存器或立即數。<域>用于設置程序狀態(tài)寄存器中需要操作的位,32位的程序狀態(tài)寄存器可分為4個(gè)域:
位[31:24]為條件標志位域,用f表示;
位[23:16]為狀態(tài)位域,用s表示;
位[15:8]為擴展位域,用x表示;
位[7:0]為控制位域,用c表示;
該指令通常用于恢復或改變程序狀態(tài)寄存器的內容,在使用時(shí),一般要在MSR指令中指明將要操作的域。
指令示例:
MSR CPSR,R0 ;傳送R0的內容到CPSR
MSR SPSR,R0 ;傳送R0的內容到SPSR
MSR CPSR_c,R0 ;傳送R0的內容到CPSR,但僅僅修改CPSR中的控制位域



評論


技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>