新聞中心

        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.104case.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)閉
        主站蜘蛛池模板: 金山区| 溧水县| 宁安市| 高密市| 衡东县| 白山市| 察隅县| 虎林市| 广东省| 武定县| 子长县| 兴隆县| 安庆市| 临沂市| 伊川县| 兴海县| 浪卡子县| 六枝特区| 大荔县| 枝江市| 丽水市| 象山县| 吴桥县| 措勤县| 舒城县| 达孜县| 蓬莱市| 香格里拉县| 汉川市| 青海省| 玉山县| 马边| 金华市| 临湘市| 日土县| 杂多县| 屏东市| 唐山市| 新巴尔虎左旗| 泽普县| 大竹县|