【ARM 常见汇编指令学习 4 -- ARM64 比较指令 cbnz 与 b.ne 区别】

文章目录

      • [B.NE 指令格式](#B.NE 指令格式)
      • [CBNZ 指令格式](#CBNZ 指令格式)

上篇文章:ARM 常见汇编指令学习 3 -- ARM64 无符号位域提取指令 UBFX
下篇文章:ARM 常见汇编指令学习 5 -- arm64汇编指令 wzr 和 xzr

B.NE 指令格式

c 复制代码
B.NE <label>

B.NE指令的含义是:如果上一个指令的结果不等于零(即条件标志位Z为0),那么跳转到指定的地址。如果结果等于零,则继续执行下一个指令。

c 复制代码
wait_rd:
	ldr x7, =0x18ac0000
	ldr w9, [x7, #0x0]
	ubfx w9, w9, #0, #1
	cmp w9, #0x1
	b.ne wait_rd
	dsb sy
	isb

上面汇编代码是判断 w90x1 是否相等,cmp 指令 可以直接影响 CPSR 寄存器的Z 标识位(条件位),比较结果为 0 时,Z位置1,比较结果为非0时,Z位为0。跳转指令时根据上一条指令的执行结果来决定跳转

CBNZ 指令格式

32-bit variant

c 复制代码
cbnz <Wt>, <label>

64-bit variant

c 复制代码
cbnz <Xt>, <label>

其中 WtXt 是通用寄存器,寄存器的号码可以是 0-31。当这个寄存器的值非零时,那么执行跳转到的地址为:当前PC+label 偏移地址。

c 复制代码
	move x0, #0x5000
wait_nop:
	nop
	subs x0, x0, #0x1
	cbnz x0, wait_nop

如上面汇编代码,是使用汇编写的延时代码 ,在代码中判断 寄存器 x0 减去1之后是否为0,如果不为0,那么继续跳转到wait_nop标签处。

上篇文章:ARM 常见汇编指令学习 3 -- ARM64 无符号位域提取指令 UBFX
下篇文章:ARM 常见汇编指令学习 5 -- arm64汇编指令 wzr 和 xzr

相关推荐
38242782721 分钟前
8086 CPU汇编伪操作汇总
汇编
渡我白衣2 小时前
C++可变参数队列与压栈顺序:从模板语法到汇编调用约定的深度解析
c语言·汇编·c++·人工智能·windows·深度学习·硬件架构
ShiMetaPi1 天前
GM-3568JHF丨ARM+FPGA异构开发板系列教程:外设教程 04 WIFI
网络·arm开发·fpga开发·智能路由器·fpga
旧梦吟1 天前
脚本语言 汇编
汇编
iCxhust1 天前
8088单板机C语言汇编混合编程实验方法与步骤
c语言·汇编·单片机·嵌入式硬件·微机原理
切糕师学AI1 天前
ARM 架构中的浮点寄存器(Floating-Point Registers)
arm开发·寄存器·浮点寄存器
再遇当年1 天前
因为研究平台arm,RK3588交叉编译误把我笔记本X86平台的/x86_64-linux-gnu文件删除,导致联想拯救者笔记本中的ubuntu系统损坏
linux·arm开发·ros·gnu·交叉编译·x86
元亓亓亓1 天前
考研408--组成原理--day8--汇编指令&不同语句的机器级表示
开发语言·汇编·c#
切糕师学AI2 天前
ARM 架构中的 CONTROL 寄存器
arm开发·硬件架构·嵌入式·芯片·寄存器
richxu202510012 天前
嵌入式学习之路>单片机核心原理篇>(14) ARM 架构
arm开发·单片机·学习