ARM裸機開發(fā)筆記5ARM指令集
以下指令中可以完成從當前指令向前或向后的32M的地址空間的跳轉(zhuǎn)
本文引用地址:http://www.ex-cimer.com/article/201611/318206.htmB{條件} 目標地址 ;花括號表示條件,可以省略
最簡單的跳轉(zhuǎn)指令,一旦遇到一個B指令,ARM處理器將立即跳轉(zhuǎn)到給定的目標地址,從那里繼續(xù)執(zhí)行
CMP R!,#0
BEQ Label ;EQ相等
當CPSR寄存器中的Z條件碼位置時,程序跳轉(zhuǎn)到標號Label處執(zhí)行
BL
BL{條件} 目標地址
跳轉(zhuǎn)之前,會在寄存器R14中保存PC當前值。因此可以通過將R14的內(nèi)容重新加載到PC中,來返回到跳轉(zhuǎn)指令之后的那個指令處執(zhí)行。該指令是實現(xiàn)子程序調(diào)用的一個基本但常用的手段。
BLX
X表示跳轉(zhuǎn)到指定地址的同時,將工作狀態(tài)從ARM狀態(tài)切換到Thumb狀態(tài),該指令同時將PC的當前內(nèi)容保存到R14中
因此當子程序使用Thumb指令集,而調(diào)用者使用ARM指令集時,可以通過BLX指令實現(xiàn)子程序的調(diào)用和處理器工作狀態(tài),同時,子程序的返回可以通過將寄存器R14值到PC中來完成。
BX 跳轉(zhuǎn)并切換狀態(tài)
數(shù)據(jù)處理指令
MOV指令
MOV{條件}{S} 目標寄存器,源操作數(shù) ----------》S加上可能會影響CPSR中的標志位。不加指令不更新CPSR。一般都不加。源操作數(shù)不可以是內(nèi)存
MVN{條件}{S} 在傳送之前把源操作數(shù)按位取反
CMP指令
TST指令 測試某一個位是否被設置了
TST R1,#%1 結(jié)果 ;用于測試在寄存器R1中是否設置了最低位(%表示二進制數(shù))對操作數(shù)1與操作數(shù)2進行按位的與運算,結(jié)果為0 ,EQ位將被設置
LDR R5,=0xffffffff
TST R5,#(1<<23) ;當bit23位為1時,CPSR EQ位被設置
MOVEQ R5,#0x00 ---->不執(zhí)行詞語據(jù),不滿足EQ
MOVNE R5,#0x01
ADD指令 加
SUB指令 減
AND 邏輯與
ORR 邏輯或
BIC Rd,Rn,operand2 用于將Rn中的某些位清零。并把結(jié)果存放在Rd中,操作數(shù)operand2為32位的掩碼,如果掩碼設置了某一位為1,則清除這一位。
BIC R0,R0,#%1011 ;將R0的0,1,3位清零,其余位保持不變。
MUL乘法指令
程序狀態(tài)字的訪問指令
MRS{條件} 通用寄存器,程序狀態(tài)寄存器(CPSR/SPSR)
將程序狀態(tài)寄存器的內(nèi)容傳送到通用寄存器中
1.當需要改變程序狀態(tài)寄存器內(nèi)容時,可用MRS將程序狀態(tài)寄存器的內(nèi)容讀入通用寄存器,修改后再寫回程序狀態(tài)寄存器。
2.當在異常處理或進程切換時,需要保存程序狀態(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ù)。<域>用于設置程序狀態(tài)寄存器中需要操作的位,32位的程序狀態(tài)寄存器可以分為4個域
位為條件標志位,用f表示。位為狀態(tài)域位,用s表示。為為擴展位域,用x表示。為為控制位域,用c表示
該指令通常用于或改變程序狀態(tài)寄存器的內(nèi)容,在使用時,一般要在MSR指令中指明將要操作的域。
MSR CPSR,R0
MSR SPSR,R0 ;傳送R0內(nèi)容帶SPSR
MSR CPSR_c,R0 ;傳送R0到CPSR,但僅僅修改CPSR中的控制位域
訪問內(nèi)存
寄存器和存儲器之間傳送數(shù)據(jù)
加載和存儲指令
LDR 目地寄存器,<存儲器地址>
從存儲器中將一個32位數(shù)據(jù)傳送到目地寄存器中
LDRB 目的寄存器,<存儲器地址>
LDRB用于從存儲器中將一個8位的字節(jié)數(shù)據(jù)傳送到目的寄存器中,同時將寄存器的高24位清零。該指令通常用于從存儲器中讀取8位的字節(jié)數(shù)據(jù)到通用寄存器,然后對數(shù)據(jù)進行處理。
LDRH
和LDRB操作類似,是取一個16位的數(shù)據(jù)
STR 源寄存器,<存儲器地址>
STR從源寄存器中將一個32為的字數(shù)據(jù)傳到存儲器中
批量加載存儲指令
LDM
STM
數(shù)據(jù)交換指令
SWP
SWPB
移位指令(邏輯移位不考慮正負號,算數(shù)移位考慮正負號)
LSL 邏輯左移
ASL 算數(shù)左移
LSR 邏輯右移
ASR 算數(shù)右移
ROR 循環(huán)右移
異常產(chǎn)生指令
ARM支持的異常產(chǎn)生指令有如下兩條
SWI:軟件中斷指令
BKPT:斷點中斷指令
評論