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

          新聞中心

          EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > ARM裸機(jī)開(kāi)發(fā)筆記5ARM指令集

          ARM裸機(jī)開(kāi)發(fā)筆記5ARM指令集

          作者: 時(shí)間:2016-11-19 來(lái)源:網(wǎng)絡(luò) 收藏
          跳轉(zhuǎn)指令:最簡(jiǎn)單的這屆修改PC的值

          以下指令中可以完成從當(dāng)前指令向前或向后的32M的地址空間的跳轉(zhuǎn)

          本文引用地址:http://www.ex-cimer.com/article/201611/318206.htm

          B{條件} 目標(biāo)地址 ;花括號(hào)表示條件,可以省略

          最簡(jiǎn)單的跳轉(zhuǎn)指令,一旦遇到一個(gè)B指令,ARM處理器將立即跳轉(zhuǎn)到給定的目標(biāo)地址,從那里繼續(xù)執(zhí)行

          CMP R!,#0

          BEQ Label ;EQ相等

          當(dāng)CPSR寄存器中的Z條件碼位置時(shí),程序跳轉(zhuǎn)到標(biāo)號(hào)Label處執(zhí)行


          BL

          BL{條件} 目標(biāo)地址

          跳轉(zhuǎn)之前,會(huì)在寄存器R14中保存PC當(dāng)前值。因此可以通過(guò)將R14的內(nèi)容重新加載到PC中,來(lái)返回到跳轉(zhuǎn)指令之后的那個(gè)指令處執(zhí)行。該指令是實(shí)現(xiàn)子程序調(diào)用的一個(gè)基本但常用的手段。

          BLX

          X表示跳轉(zhuǎn)到指定地址的同時(shí),將工作狀態(tài)從ARM狀態(tài)切換到Thumb狀態(tài),該指令同時(shí)將PC的當(dāng)前內(nèi)容保存到R14中

          因此當(dāng)子程序使用Thumb指令集,而調(diào)用者使用ARM指令集時(shí),可以通過(guò)BLX指令實(shí)現(xiàn)子程序的調(diào)用和處理器工作狀態(tài),同時(shí),子程序的返回可以通過(guò)將寄存器R14值到PC中來(lái)完成。

          BX 跳轉(zhuǎn)并切換狀態(tài)

          數(shù)據(jù)處理指令

          MOV指令

          MOV{條件}{S} 目標(biāo)寄存器,源操作數(shù) ----------》S加上可能會(huì)影響CPSR中的標(biāo)志位。不加指令不更新CPSR。一般都不加。源操作數(shù)不可以是內(nèi)存

          MVN{條件}{S} 在傳送之前把源操作數(shù)按位取反

          CMP指令

          TST指令 測(cè)試某一個(gè)位是否被設(shè)置了

          TST R1,#%1 結(jié)果 ;用于測(cè)試在寄存器R1中是否設(shè)置了最低位(%表示二進(jìn)制數(shù))對(duì)操作數(shù)1與操作數(shù)2進(jìn)行按位的與運(yùn)算,結(jié)果為0 ,EQ位將被設(shè)置

          LDR R5,=0xffffffff
          TST R5,#(1<<23) ;當(dāng)bit23位為1時(shí),CPSR EQ位被設(shè)置

          MOVEQ R5,#0x00 ---->不執(zhí)行詞語(yǔ)據(jù),不滿足EQ
          MOVNE R5,#0x01

          ADD指令 加

          SUB指令 減

          AND 邏輯與

          ORR 邏輯或

          BIC Rd,Rn,operand2 用于將Rn中的某些位清零。并把結(jié)果存放在Rd中,操作數(shù)operand2為32位的掩碼,如果掩碼設(shè)置了某一位為1,則清除這一位。

          BIC R0,R0,#%1011 ;將R0的0,1,3位清零,其余位保持不變。

          MUL乘法指令

          程序狀態(tài)字的訪問(wèn)指令

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

          將程序狀態(tài)寄存器的內(nèi)容傳送到通用寄存器中

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

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

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

          MSR指令

          MSR 程序狀態(tài)寄存器(CPSR/SPSR)_<域> ,操作數(shù)

          將操作數(shù)的內(nèi)容傳送到程序狀態(tài)寄存器或其特定域中。其中操作數(shù)可以是通用寄存器或立即數(shù)。<域>用于設(shè)置程序狀態(tài)寄存器中需要操作的位,32位的程序狀態(tài)寄存器可以分為4個(gè)域

          位為條件標(biāo)志位,用f表示。位為狀態(tài)域位,用s表示。為為擴(kuò)展位域,用x表示。為為控制位域,用c表示

          該指令通常用于或改變程序狀態(tài)寄存器的內(nèi)容,在使用時(shí),一般要在MSR指令中指明將要操作的域。

          MSR CPSR,R0

          MSR SPSR,R0 ;傳送R0內(nèi)容帶SPSR

          MSR CPSR_c,R0 ;傳送R0到CPSR,但僅僅修改CPSR中的控制位域

          訪問(wèn)內(nèi)存

          寄存器和存儲(chǔ)器之間傳送數(shù)據(jù)

          加載和存儲(chǔ)指令

          LDR 目地寄存器,<存儲(chǔ)器地址>

          從存儲(chǔ)器中將一個(gè)32位數(shù)據(jù)傳送到目地寄存器中

          LDRB 目的寄存器,<存儲(chǔ)器地址>

          LDRB用于從存儲(chǔ)器中將一個(gè)8位的字節(jié)數(shù)據(jù)傳送到目的寄存器中,同時(shí)將寄存器的高24位清零。該指令通常用于從存儲(chǔ)器中讀取8位的字節(jié)數(shù)據(jù)到通用寄存器,然后對(duì)數(shù)據(jù)進(jìn)行處理。

          LDRH

          和LDRB操作類似,是取一個(gè)16位的數(shù)據(jù)

          STR 源寄存器,<存儲(chǔ)器地址>

          STR從源寄存器中將一個(gè)32為的字?jǐn)?shù)據(jù)傳到存儲(chǔ)器中

          批量加載存儲(chǔ)指令

          LDM

          STM

          數(shù)據(jù)交換指令

          SWP

          SWPB

          移位指令(邏輯移位不考慮正負(fù)號(hào),算數(shù)移位考慮正負(fù)號(hào))

          LSL  邏輯左移

          ASL 算數(shù)左移

          LSR 邏輯右移

          ASR 算數(shù)右移

          ROR 循環(huán)右移

          異常產(chǎn)生指令

          ARM支持的異常產(chǎn)生指令有如下兩條

          SWI:軟件中斷指令

          BKPT:斷點(diǎn)中斷指令



          評(píng)論


          技術(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); })();