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

文章目录

      • B.NE 指令格式
      • CBNZ 指令格式

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

B.NE 指令格式

B.NE <label>

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

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

cbnz <Wt>, <label>

64-bit variant

cbnz <Xt>, <label>

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

	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

你可能感兴趣的:(#,ARM,常见汇编指令学习,arm开发,汇编,cbnz,b.nq)