<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

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

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

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

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

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

          本文引用地址:http://www.ex-cimer.com/article/201611/321997.htm
          SPSR:程序狀態(tài)保存寄存器,用于保存CPSR的狀態(tài),以便異常返回后恢復(fù)異常發(fā)生時的工作狀態(tài)。
          對于CPSR只有1個,對于SPSR有5個(Supervisor/abort/Undefined/interrupt/Fast各有1個):

          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)志。例:MRSR0,CRSR;將CPSR中的內(nèi)容傳送至R0MRSR3,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個域:
          位[31:24]為條件標(biāo)志位域,用f表示;
          位[23:16]為狀態(tài)位域,用s表示;
          位[15:8]為擴(kuò)展位域,用x表示;
          位[7:0]為控制位域,用c表示;
          該指令通常用于恢復(fù)或改變程序狀態(tài)寄存器的內(nèi)容,在使用時,一般要在MSR指令中指明將要操作的域。
          指令示例:
          MSR CPSR,R0 ;傳送R0的內(nèi)容到CPSR
          MSR SPSR,R0 ;傳送R0的內(nèi)容到SPSR
          MSR CPSR_c,R0 ;傳送R0的內(nèi)容到CPSR,但僅僅修改CPSR中的控制位域



          評論


          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();