汇编语法及相关指令

1.汇编指令的基本格式:

<opcode>{<cond>}{s} <Rd>, <Rn>, <shifter_operand>

opcode:指令的功能码,用来表示当前指令的作用

cond:条件码,需要在指令执行之前先判断条件受否满足,不满足则指令不执行

s:影响CPSR条件位

Rd:目标寄存器

Rn:第一操作寄存器

2.常见指令:

数据搬移指令:

mov{条件码} 目标寄存器 操作数

将操作数搬移到目标寄存器中

mvn{条件码} 目标寄存器 操作数

将操作数按位取反后结果搬移到目标寄存器中

数据移位指令:

逻辑左移: lsl{条件码} 目标寄存器,第一操作寄存器,第二操作数

将第一操作寄存器的数据左移第二操作数位数,结果保存到目标寄存器

逻辑右移: lsr{条件码} 目标寄存器,第一操作寄存器,第二操作数

将第一操作寄存器的数据右移第二操作数位数,结果保存到目标寄存器

循环右移 :ror{条件码} 目标寄存器,第一操作寄存器,第二操作数

将第一操作寄存器的数据循环右移第二操作数位数,结果保存到目标寄存器

位运算指令

and{条件码} 目标寄存器,第一操作寄存器,第二操作数

与运算 与0清零,与1不变

orr{条件码} 目标寄存器,第一操作寄存器,第二操作数

或运算 有1位1,全0为0

eor{条件码} 目标寄存器,第一操作寄存器,第二操作数

异或运算 相同为0,不同为1

bic{条件码} 目标寄存器,第一操作寄存器,第二操作数

按位清零运算

mvn 按位取反

算术运算指令:

add{条件码}{s} 目标寄存器,第一操作寄存器,第二操作数

目标寄存器=第一操作寄存器+第二操作数

考虑cpsr条件位的加法指令 adc{条件码}{s} 目标寄存器,第一操作寄存器,第二操作数

目标寄存器=第一操作寄存器+第二操作数+cpsr寄存器c位的值

减法指令 sub{条件码}{s} 目标寄存器,第一操作寄存器,第二操作数

目标寄存器=第一操作寄存器-第二操作数 4.

考虑cpsr条件位的减法指令 SBC{条件码}{s} 目标寄存器,第一操作寄存器,第二操作数

目标寄存器=第一操作寄存器-第二操作数-cpsr寄存器c位的取反值

乘法运算 mul{条件码}{s} 目标寄存器,第一操作寄存器,第二操作数

目标寄存器=第一操作寄存器*第二操作数

比较指令:

cmp 第一操作寄存器,第二操作数

将第一操作数和第二操作寄存器进行比较

tst 目标寄存器,#(0X1<<N)

这个指令用来判断目标寄存器的第N位是否为0

TEQ 目标寄存器,第二操作数

判断目标寄存器的值是否和第二操作数相等

跳转指令:

b 标签

跳转到指定的标签下,跳转后LR寄存器不保存程序返回地址

bl 标签

跳转到指定的标签下,跳转后LR寄存器保存程序返回地址

相关推荐
听风lighting17 小时前
C语言八股---预处理,编译,汇编与链接篇
c语言·开发语言·汇编
物随心转2 天前
汇编的伪指令
汇编·arm开发
Moonnnn.2 天前
51单片机——程序执行过程(手工汇编)
汇编·笔记·嵌入式硬件·学习·51单片机
却道天凉_好个秋2 天前
c++ 嵌入汇编的方式实现int型自增
开发语言·汇编·c++
白晨并不是很能熬夜2 天前
【JVM】字节码指令集
java·开发语言·汇编·jvm·数据结构·后端·javac
Moonnnn.2 天前
51单片机——汇编工程建立、仿真、调试全过程
汇编·笔记·嵌入式硬件·学习·51单片机
禾仔仔3 天前
RISC-V汇编学习(三)—— RV指令集
汇编·risc-v·指令集
leluckys3 天前
swift -(5) 汇编分析结构体、类的内存布局
汇编
cheungxiongwei.com4 天前
ESP32-P4 支持哪些 RISC-V 汇编指令?
汇编·risc-v
charlie1145141916 天前
从0开始的操作系统手搓教程21:进程子系统的一个核心功能——简单的进程切换
汇编·学习·操作系统·线程·进程·手搓教程