汇编指令解读

16位数据操作指令

名字功能
ADC带进位加法(ADD with Carry)
ADD加法
AND按位与。这里的按位与和C的”&”功能相同
ASR算术右移(Arithmetic Shift Right)
BIC按位清零(把一个数跟另一个无符号数的反码按位与)
CMN负向比较(把一个数跟另一个数据的二进制补码相比较)
CMP比较(Compare,比较两个数并且更新标志)
CPY把一个寄存器的值拷贝(COPY)到另一个寄存器中
EOR近位异或
LSL逻辑左移(Logic Shift Left)
LSR逻辑右移(Logic Shift Right)
MOV寄存器加载数据,既能用于寄存器间的传输,也能用于加载立即数
MUL乘法(Multiplication)
MVN加载一个数的 NOT值(取到逻辑反的值)
NEG取二进制补码
ORR按位或
ROR循环右移
SBC带借位的减法
SUB减法(Subtraction)
TST测试(Test,执行按位与操作,并且根据结果更新Z)
REV在一个32位寄存器中反转(Reverse)字节序
REVH把一个32位寄存器分成两个(Half)16位数,在每个16位数中反转字节序
REVSH把一个32位寄存器的低16位半字进行字节反转,然后带符号扩展到32位
SXTB带符号(Signed)扩展一个字节(Byte)到 32位
SXTH带符号(Signed)扩展一个半字(Half)到 32位
UXTB无符号(Unsigned)扩展一个字节(Byte)到 32位
UXTH无符号(Unsigned)扩展一个半字(Half)到 32位

16位转移指令

名字功能
B无条件转移(Branch)
B有条件(Condition)转移
BL转移并连接(Link)。用于呼叫一个子程序,返回地址被存储在LR中
CBZ比较(Compare),如果结果为零(Zero)就转移(只能跳到后面的指令)
CBNZ比较,如果结果非零(Non Zero)就转移(只能跳到后面的指令)
ITIf-Then

16位存储器数据传送指令

名字功能
LDR从存储器中加载(Load)字到一个寄存器(Register)中
LDRH从存储器中加载半(Half)字到一个寄存器中
LDRB从存储器中加载字节(Byte)到一个寄存器中
LDRSH从存储器中加载半字,再经过带符号扩展后存储一个寄存器中
LDRSB从存储器中加载字节,再经过带符号扩展后存储一个寄存器中
STR把一个寄存器按字存储(Store)到存储器中
STRH把一个寄存器存器的低半字存储到存储器中
STRB把一个寄存器的低字节存储到存储器中
LDMIA加载多个字,并且在加载后自增基址寄存器
STMIA存储多个字,并且在存储后自增基址寄存器
PUSH压入多个寄存器到栈中
POP从栈中弹出多个值到寄存器中

其它16位指令

名字功能
SVC系统服务调用(Service Call)
BKPT断点(Break Point)指令。如果调试被使能,则进入调试状态(停机)。
NOP 无操作(No Operation)
CPSIE使能 PRIMASK(CPSIE i)/FAULTMASK(CPSIE f)——清零相应的位
CPSID除能 PRIMASK(CPSID i)/FAULTMASK(CPSID f)——置位相应的位

32位数据操作指令

名字功能
ADC带进位加法
ADD加法
ADDW宽加法(可以加 12 位立即数)
AND按位与(原文是逻辑与,有误——译注)
ASR算术右移
BIC位清零(把一个数按位取反后,与另一个数逻辑与)
BFC位段清零
BFI位段插入
CMN负向比较(把一个数和另一个数的二进制补码比较,并更新标志位)
CMP比较两个数并更新标志位
CLZ计算前导零的数目
EOR按位异或
LSL逻辑左移
LSR逻辑右移
MLA乘加
MLS乘减
MOVW把 16 位立即数放到寄存器的底16位,高16位清0
MOV加载16位立即数到寄存器(其实汇编器会产生MOVW——译注)
MOVT把 16 位立即数放到寄存器的高16位,低 16位不影响
MVN移动一个数的补码
MUL乘法
ORR按位或(原文为逻辑或,有误——译注)
ORN把源操作数按位取反后,再执行按位或(原文为逻辑或,有误——译注)
RBIT位反转(把一个 32 位整数先用2 进制表达,再旋转180度——译注)
REV对一个32 位整数做按字节反转
REVH/REV16对一个32 位整数的高低半字都执行字节反转
REVSH对一个32 位整数的低半字执行字节反转,再带符号扩展成32位数
ROR圆圈右移
RRX带进位的逻辑右移一格(最高位用C 填充,且不影响C的值——译注)
SFBX从一个32 位整数中提取任意的位段,并且带符号扩展成 32 位整数
SDIV带符号除法
SMLAL带符号长乘加(两个带符号的 32 位整数相乘得到 64 位的带符号积,再把积加到另一个带符号 64位整数中)
SMULL带符号长乘法(两个带符号的 32 位整数相乘得到 64位的带符号积)
SSAT带符号的饱和运算
SBC带借位的减法
SUB减法
SUBW宽减法,可以减 12 位立即数
SXTB字节带符号扩展到32位数
TEQ测试是否相等(对两个数执行异或,更新标志但不存储结果)
TST测试(对两个数执行按位与,更新Z 标志但不存储结果)
UBFX无符号位段提取
UDIV无符号除法
UMLAL无符号长乘加(两个无符号的 32 位整数相乘得到 64 位的无符号积,再把积加到另一个无符号 64位整数中)
UMULL无符号长乘法(两个无符号的 32 位整数相乘得到 64位的无符号积)
USAT无符号饱和操作(但是源操作数是带符号的——译注)
UXTB字节被无符号扩展到32 位(高24位清0——译注)
UXTH半字被无符号扩展到32 位(高16位清0——译注)

32位存储器数据传送指令

名字功能
LDR加载字到寄存器
LDRB加载字节到寄存器
LDRH加载半字到寄存器
LDRSH加载半字到寄存器,再带符号扩展到 32位
LDM从一片连续的地址空间中加载多个字到若干寄存器
LDRD从连续的地址空间加载双字(64 位整数)到2 个寄存器
STR存储寄存器中的字
STRB存储寄存器中的低字节
STRH存储寄存器中的低半字
STM存储若干寄存器中的字到一片连续的地址空间中
STRD存储2 个寄存器组成的双字到连续的地址空间中
PUSH把若干寄存器的值压入堆栈中
POP从堆栈中弹出若干的寄存器的值

32位转移指令

名字功能
B无条件转移
BL转移并连接(呼叫子程序)
TBB以字节为单位的查表转移。从一个字节数组中选一个8位前向跳转地址并转移
TBH以半字为单位的查表转移。从一个半字数组中选一个16 位前向跳转的地址并转移

其它32位指令

名字功能
LDREX加载字到寄存器,并且在内核中标明一段地址进入了互斥访问状态
LDREXH加载半字到寄存器,并且在内核中标明一段地址进入了互斥访问状态
LDREXB加载字节到寄存器,并且在内核中标明一段地址进入了互斥访问状态
STREX检查将要写入的地址是否已进入了互斥访问状态,如果是则存储寄存器的字
STREXH检查将要写入的地址是否已进入了互斥访问状态,如果是则存储寄存器的半字
STREXB检查将要写入的地址是否已进入了互斥访问状态,如果是则存储寄存器的字节
CLREX在本地的处理上清除互斥访问状态的标记(先前由 LDREX/LDREXH/LDREXB做的标记)
MRS加载特殊功能寄存器的值到通用寄存器
MSR存储通用寄存器的值到特殊功能寄存器
NOP无操作
SEV发送事件
WFE休眠并且在发生事件时被唤醒
WFI休眠并且在发生中断时被唤醒
ISB指令同步隔离(与流水线和 MPU等有关——译注)
DSB数据同步隔离(与流水线、MPU 和cache等有关——译注)
DMB数据存储隔离(与流水线、MPU 和cache等有关——译注)
  • 11
    点赞
  • 74
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值