【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

相关推荐
AndyHeee9 小时前
【SVC、PendSV(系统异常) 与 外设 IRQ 、NVIC笔记】
arm开发
暮云星影11 小时前
瑞芯微rk3588利用Rockchip NPU运行大语言模型(LLM)
arm开发·人工智能·语言模型·自然语言处理
techdashen11 小时前
绕过系统 ICMP:用 rawsock、Npcap 和 WMI 找到默认网卡
开发语言·arm开发·rust
ThornArmor12 小时前
【工具篇·番外】跨语言生态的主权回收:基于 ISA 说明书的 4-bit 双向汇编系统全线封顶
c语言·开发语言·汇编·c++·重构·架构
振南的单片机世界13 小时前
ARM中断比51快在哪?硬件压栈+NVIC集中管理
arm开发·stm32·单片机·嵌入式硬件
墨绿色的摆渡人14 小时前
论文笔记(一百三十七)Learning Dual-Arm Push and Grasp Synergy in Dense Clutter
arm开发·论文阅读
暮云星影1 天前
全志linux开发屏幕适配(一)屏幕参数设置说明
linux·arm开发
是星辰吖~1 天前
WIN32_线程(下)
汇编
m0_547486661 天前
《ARM Cortex-M4嵌入式应用技术——基于STM32F407、STM32CubeMX与Proteus》全套PPT课件
arm开发·stm32·proteus
Lanceli_van1 天前
SQLite 3.45.2(sqlite-autoconf-3450200)ARM 交叉编译完整步骤
arm开发·sqlite