文档介绍:ARM 汇编指令集
一、 跳转指令
跳转指令用于实现程序流程的跳转,在 ARM
跳转:
Ⅰ.使用专门的跳转指令。
Ⅱ.直接向程序计数器 PC 写入跳转地址值。
通过向程序计数器 PC 写入跳转地址值,可以实现在
转之前结合使用
程序中有两种方法可以实现程序流程的
4GB 的地址空间中的任意跳转,在跳
MOV LR
, PC
等类似指令,可以保存将来的返回地址值,从而实现在
4GB
连续的线性地址空间的子程序
调用。
ARM 指令集中的跳转指令可以完成从当前指令向前或向后的
转,包括以下 4 条指令:
1、 B指令
32MB
的地址空间的跳
指令的格式为:
B{ 条件 } 目标地址
B 指令是最简单的跳转指令。一旦遇到一个 B 指令, ARM 处理器将立即跳转到给定
的目标地址,从那里继续执行。注意存储在跳转指令中的实际值是相对当前 PC 值的一个偏
移量,而不是一个绝对地址, 它的值由汇编器来计算 (参考寻址方式中的相对寻址) 。它是 24
位有符号数,左移两位后有符号扩展为 32 位,表示的有效偏移为 26 位 (前后 32MB 的地址空间 )。以下指令:
B Label
CMP R1 ,# 0
;程序无条件跳转到标号
;当 CPSR 寄存器中的
Label 处执行
Z 条件码置位时,程序跳转到标号
Label
处执行
BEQ Label
2、
BL
指令
BL 指令的格式为:
BL{ 条件 } 目标地址
BL 是另一个跳转指令,但跳转之前,会在寄存器 R14 中保存 PC 的当前内容,因此,
可以通过将 R14
的内容重新加载到 PC 中,来返回到跳转指令之后的那个指令处执行。该
指令是实现子程序调用的一个基本但常用的手段。以下指令:
BLLabel
;当程序无条件跳转到标号
Label 处执行时,同时将当前的
PC 值
保存
到R14中
3、
BLX 指令
BLX 指令的格式为:
BLX
目标地址
BLX 指令从 ARM 指令集跳转到指令中所指定的目标地址,并将处理器的工作状态有
ARM
状态切换到 Thumb 状态,该指令同时将
PC 的当前内容保存到寄存器
R14 中。因此,当子
程序使用 Thumb 指令集,而调用者使用
ARM 指令集时,可以通过
BLX 指令实现子程序的
调用和处理器工作状态的切换。
同时,子程序的返回可以通过将寄存器
R14 值复制到 PC 中
来完成。
4、
BX 指令
BX 指令的格式为:
BX{ 条件 } 目标地址
BX 指令跳转到指令中所指定的目标地址,目标地址处的指令既可以是 ARM 指令,也可以
是 Thumb 指令。
二、数据处理指令数据处理指令可分为数据传送指令、算术逻辑运算指令和比较指令等。数据传送指令用于在寄存器和存储器之间进行数据的双向传输。
算术逻辑运算指令完成常用的算术与逻辑的运算, 该类指令不但将运算结果保存在目的寄存器中,同时更新 CPSR 中的相应条件标志位。
比较指令不保存运算结果,只更新 CPSR 中相应的条件标志位。数据处理指令共以下 16 条。
1、 MOV 指令
MOV 指令的格式为:
MOV{ 条件 }{S} 目的寄存器,源操作数
MOV 指令可完成从另一个寄存器、被移位的寄存器或将一个立即数加载到目的寄存器。其
中 S 选项决定指令的操作是否影响 CPSR 中条件标志位的值, 当没有 S 时指令不更新 CPSR
中条件标志位的值。
指令示例:
MOV R1 , R0
MOV PC , R14
;将寄存器
;将寄存器
R0 的值传送到寄存器 R1
R14 的值传送到 PC,常用于子程序返
回
MOV R1 , R0,LSL # 3
2、 MVN 指令
;将寄存器
R0 的值左移
3 位后传送到
R1
MVN 指令的格式为:
MVN