主要介紹ARM微處理器指令集對應的概念,與其一般編碼格式,可以為大家提供快速查詢的便利,但要注意的是本文整理的是ARMv5TE及以下版本的微處理器,對于更高級的版本,可能會有新的指令出現(xiàn),所以請注意查看自己使用的ARM處理器型號。
一、跳轉(zhuǎn)指令
1、B指令——跳轉(zhuǎn)指令
指令格式:B{條件} 目標地址
2、BL指令——帶返回的跳轉(zhuǎn)指令
指令格式:BL{條件} 目標地址
3、BLX指令——帶返回和狀態(tài)切換的跳轉(zhuǎn)指令
指令格式:BLX 目標地址
4、BX指令——帶狀態(tài)切換的跳轉(zhuǎn)指令
指令格式:BX{條件} 目標地址
二、數(shù)據(jù)處理指令
數(shù)據(jù)處理分為傳輸指令、算術邏輯指令和比較指令。
1、MOV指令——數(shù)據(jù)傳輸指令
指令格式:MOV{條件} {S} 目的寄存器,源操作數(shù)
2、MVN指令——取反傳送指令
指令格式:MVN{條件} {S} 目的寄存器,源操作數(shù)
3、CMP指令——比較指令
指令格式:CMP{條件} {S} 操作數(shù)1,操作數(shù)2
4、CMN指令——反值比較指令
指令格式:CMN{條件} 操作數(shù)1,操作數(shù)2
5、TST指令——位測試指令
指令格式:TST{條件} 操作數(shù)1,操作數(shù)2
6、TEQ指令——相等測試指令
指令格式:TEQ{條件} 操作數(shù)1,操作數(shù)2
7、ADD指令——加法指令
指令格式:ADD{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2
8、ADC指令——帶進位的加法指令
指令格式:ADC{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2
9、SUB指令——減法指令
指令格式:SUB{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2
10、SBC指令——帶借位的減法指令
指令格式:SBC{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2
11、RSB指令——逆向減法指令
指令格式:RSB{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2
12、RSC指令——帶借位的逆向減法指令
指令格式:RSC{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2
13、AND指令——邏輯“與”指令
指令格式:AND{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2
14、ORR指令——邏輯“或”指令
指令格式:ORR{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2
15、EOR指令——邏輯“異或”指令
指令格式:EOR{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2
16、BIC指令——位清除指令
指令格式:BIC{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2
三、乘法指令與乘加指令
1、MUL指令——32位乘法指令
指令格式:MUL{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2
2、MLA指令——32位乘加指令
指令格式:MLA{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2,操作數(shù)3
3、SMULL指令——64位有符號數(shù)乘法指令
指令格式:SMULL{條件} {S} 目的寄存器Low,目的寄存器High,操作數(shù)1,操作數(shù)2
4、SMLAL指令——64位有符號數(shù)乘加指令
指令格式:SMLAL{條件} {S} 目的寄存器Low,目的寄存器High,操作數(shù)1,操作數(shù)2
5、UMULL指令——64位無符號數(shù)乘法指令
指令格式:UMULL{條件} {S} 目的寄存器Low,目的寄存器High,操作數(shù)1,操作數(shù)2
6、UMLAL指令——64位無符號數(shù)乘加指令
指令格式:UMLAL{條件} {S} 目的寄存器Low,目的寄存器High,操作數(shù)1,操作數(shù)2
四、程序狀態(tài)寄存器指令
1、MRS指令——程序狀態(tài)寄存器到通用寄存器的數(shù)據(jù)傳輸指令
指令格式:MRS{條件} 通用寄存器,程序狀態(tài)寄存器(CPSR或SPSR)
2、MSR指令——通用寄存器到程序狀態(tài)寄存器的數(shù)據(jù)傳輸指令
指令格式:MSR{條件} 程序狀態(tài)寄存器(CPSR或SPSR)_<域>,操作數(shù)
五、加載/存儲指令
1、LDR指令——字數(shù)據(jù)加載指令
指令格式:LDR{條件} 目的寄存器,<存儲器地址>
2、LDRB指令——字節(jié)數(shù)據(jù)加載指令
指令格式:LDR{條件} B 目的寄存器,<存儲器地址>
3、LDRH指令——半字數(shù)據(jù)加載指令
指令格式:LDR{條件}H 目的寄存器,<存儲器地址>
4、STR指令——字數(shù)據(jù)存儲指令
指令格式:STR{條件} 源寄存器,<存儲器地址>
5、STRB指令——字節(jié)數(shù)據(jù)存儲指令
指令格式:STR{條件}B 源寄存器,<存儲器地址>
6、STRH指令——半字數(shù)據(jù)存儲指令
指令格式:STR{條件}H 源寄存器,<存儲器地址>
六、批量數(shù)據(jù)加載/存儲指令
1、LDM指令——批量數(shù)據(jù)加載指令
指令格式:LDM{條件} {類型} 基址寄存器{!},寄存器列表{^}
2、STM指令——批量數(shù)據(jù)存儲指令
指令格式:STM{條件} {類型} 基址寄存器{!},寄存器列表{^}
七、數(shù)據(jù)交換指令
1、SWP指令——字數(shù)據(jù)交換指令
指令格式:SWP{條件} 目的寄存器,源寄存器1,[源寄存器2]
2、SWPB指令——字節(jié)數(shù)據(jù)交換指令
指令格式:SWP{條件}B 目的寄存器,源寄存器1,[源寄存器2]
八、移位指令
1、LSL指令——對通用寄存器中的內(nèi)容進行邏輯左移操作
指令格式:通用寄存器,LSL 操作數(shù)
2、ASL指令——對通用寄存器中的內(nèi)容進行算術左移操作
指令格式:通用寄存器,ASL 操作數(shù)
3、LSR指令——對通用寄存器中的內(nèi)容進行邏輯右移操作
指令格式:通用寄存器,LSR 操作數(shù)
4、ASR指令——對通用寄存器中的內(nèi)容進行算術右移操作
指令格式:通用寄存器,ASR 操作數(shù)
5、ROR指令——對通用寄存器中的內(nèi)容進行循環(huán)右移操作
指令格式:通用寄存器,ROR 操作數(shù)
6、RRX指令——對通用寄存器中的內(nèi)容進行帶擴展的循環(huán)右移操作
指令格式:通用寄存器,RRX 操作數(shù)
九、協(xié)處理器指令
1、CDP指令——ARM處理器通知ARM協(xié)處理器執(zhí)行特定的操作,若協(xié)處理器不能成功完成特定操作,則產(chǎn)生未定義指令異常
指令格式:CDP{條件}協(xié)處理器編碼,協(xié)處理器操作碼1,目的寄存器,源寄存器1,寄存器2,協(xié)處理器操作碼2
2、LDC指令——將源寄存器所指向的存儲器中的字數(shù)據(jù)傳送到目的寄存器中,若協(xié)處理器不能成功完成傳送操作,則產(chǎn)生未定義指令異常。
指令格式:LDC{條件} {L} 協(xié)處理器編碼,目的寄存器,[源寄存器]
3、STC指令——將源寄存器中的字數(shù)據(jù)傳送到目的寄存器所指向的存儲器中,若協(xié)處理器不能成功完成傳送操作,則產(chǎn)生未定義指令異常。
指令格式:STC{條件} {L} 協(xié)處理器編碼,源寄存器,[目的寄存器]
4、MCR指令——將ARM處理器寄存器中的數(shù)據(jù)傳送到協(xié)處理器寄存器中,若協(xié)處理器不能完成此操作,則產(chǎn)生未定義指令異常。
指令格式:MCR{條件}協(xié)處理器編碼,協(xié)處理器操作碼1,源寄存器,目的寄存器1,目的寄存器2,協(xié)處理器操作碼2
5、MRC指令——將協(xié)處理器寄存器中的數(shù)據(jù)傳送到ARM處理器寄存器中,若協(xié)處理器不能成功完成操作,則產(chǎn)生未定義指令異常。
指令格式:MRC{條件}協(xié)處理器編碼,協(xié)處理器操作碼1,目的寄存器,源寄存器1,源寄存器2,協(xié)處理器操作碼2
十、異常中斷指令
1、SWI指令——軟件中斷指令
指令格式:SWI{條件}24位的立即數(shù)
2、BKPT指令——斷點中斷指令
指令格式:BKPT 16位的立即數(shù)