【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

相关推荐
丁总学Java6 小时前
ARM 架构(Advanced RISC Machine)精简指令集计算机(Reduced Instruction Set Computer)
arm开发·架构
韦德斯1 天前
嵌入式Linux的RTC读写操作应用
linux·运维·c语言·arm开发·实时音视频
byte轻骑兵1 天前
嵌入式 ARM Linux 系统构成全解:从硬件到应用层层剖析
linux·arm开发·arm·嵌入式开发
思尔芯S2C2 天前
面向未来的智能视觉参考设计与汽车架构,思尔芯提供基于Arm技术的创新方案
arm开发·架构·汽车·iot·fpga原型验证·prototyping·智慧视觉
Crossoads2 天前
【汇编语言】call 和 ret 指令(一) —— 探讨汇编中的ret和retf指令以及call指令及其多种转移方式
android·开发语言·javascript·汇编·人工智能·数据挖掘·c#
Eternal-Student2 天前
【docker了解】如何将x86镜像转换为适用于Jetson的ARM镜像
arm开发·docker·容器
不怕犯错,就怕不做3 天前
修复kernel编译栈帧大小异常问题error: the frame size of 1928 bytes is larger than 1024 bytes
linux·arm开发·驱动开发
Crossoads3 天前
【汇编语言】转移指令的原理(三) —— 汇编跳转指南:jcxz、loop与位移的深度解读
android·汇编·人工智能·redis·单片机·深度学习·机器学习
zhuqiyua3 天前
深入解析Kernel32.dll与Msvcrt.dll
汇编·microsoft·windbg·二进制·dll
憧憬一下4 天前
UART硬件介绍
arm开发·嵌入式硬件·串口·嵌入式·linux驱动开发