色婷婷AⅤ一区二区三区|亚洲精品第一国产综合亚AV|久久精品官方网视频|日本28视频香蕉

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > ARM匯編指令集之六——程序狀態(tài)寄存器訪問指令

          ARM匯編指令集之六——程序狀態(tài)寄存器訪問指令

          作者: 時間:2016-11-09 來源:網(wǎng)絡(luò) 收藏
          1、 MRS指令

          MRS指令的格式為:

          本文引用地址:http://cafeforensic.com/article/201611/317602.htm

          MRS{條件}通用寄存器,程序狀態(tài)寄存器(CPSR或SPSR)

          MRS指令用于將程序狀態(tài)寄存器的內(nèi)容傳送到通用寄存器中。該指令一般用在以下兩種情況:

          Ⅰ.當(dāng)需要改變程序狀態(tài)寄存器的內(nèi)容時,可用MRS將程序狀態(tài)寄存器的內(nèi)容讀入通用寄存器,修改后再寫回程序狀態(tài)寄存器。

          Ⅱ.當(dāng)在異常處理或進(jìn)程切換時,需要保存程序狀態(tài)寄存器的值,可先用該指令讀出程序狀態(tài)寄存器的值,然后保存。

          指令示例:

          MRS R0,CPSR;傳送CPSR的內(nèi)容到R0

          MRS R0,SPSR;傳送SPSR的內(nèi)容到R0

          2、 MSR指令

          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)容到SPSR,但僅僅修改CPSR中的控制位域


          評論


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

          關(guān)閉