ARM指令集介绍
7种工作模式,2种工作状态
ARM指令的种类,共有7类指令,可以完成存储器访问,数据运算,程序跳转,处理器控制,以及帮助编程的伪指令等。
数据处理指令大致分为三类:
a.数据传送指令
b.算数逻辑运算指令
c.比较指令
数据处理指令只能对寄存器的内容进行操作,而不能对内存中的数据进行操作。所有的ARM数据处理指令均可以选择使用S后缀,并影响状态标志。
数据传送指令
MOV 指令可将8位图立即数或寄存器传送到目标寄存器,可用移位运算等操作
同类型的指令还有MVN,它可以实现数据的 非传递 ,即把操作数取反后送至目标寄存器
MOV指令与LDR指令都是往目标寄存器中传送数据,但是它们有什么区别吗?
MOV指令用于将数据从一个寄存器传送到另一个寄存器中,或者将一个常数传送到一个寄存器中,但是不能访问内存。LDR指令用于从内存在洪读取数据放入寄存器中。
算术逻辑指令
部分算数运算符
ADD 加法运算
ADC 带进位的加法运算
SUB 减法运算
RSB 逆向减法运算
SBC 带进位的减法运算
RSC 带进位逆向减法运算
部分逻辑运算符
AND 逻辑与运算
ORR 逻辑或运算
EOR 逻辑异或运算
BIC 位清除运算
比较运算符:
CMP: 数值比较
CMN: 负数比较
TST: 位测试
TEQ: 相等测试
乘法指令:
32 * 32 位乘法指令; MUL
32 * 32 位乘加指令; MLA
32 * 32 位结果为64位的乘/乘加指令。
MUL R3,R2,R1 ;
R3=R1 * R2
MLA R3,R2,R1,R0 ;
R3=R2 *R1 +R0
跳转指令:
B: 分支指令
BL :带链接的分支指令
BX:带状态切换的分支指令
ARM伪指令有四条
a.小范围地址读取指令:ADR
b.中等范围地址读取指令:ADRL
c.大等范围地址读取指令:LDR
d.空操作指令:NOP
地址表达式
352

被折叠的 条评论
为什么被折叠?



