【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

相关推荐
wdfk_prog1 天前
[Linux]学习笔记系列 -- [arm][lds]
linux·运维·arm开发·笔记·学习
szxinmai主板定制专家1 天前
基于FPGA的热电偶测温数据采集系统,替代NI的产品(二)总体设计方案
arm开发·人工智能·嵌入式硬件·fpga开发
cici158743 天前
ARM保留的标准中断处理程序入口和外设中断处理程序入口介绍
arm开发
学不动CV了3 天前
FreeRTOS入门知识(初识RTOS任务调度)(三)
c语言·arm开发·stm32·单片机·物联网·算法·51单片机
程序员JerrySUN4 天前
四级页表通俗讲解与实践(以 64 位 ARM Cortex-A 为例)
java·arm开发·数据库·redis·嵌入式硬件·缓存
要记得喝水4 天前
汇编中常用寄存器介绍
开发语言·汇编·windows·c#·.net
zhmc4 天前
MCU程序的ARM-GCC编译链接
arm开发·单片机·嵌入式硬件
wdfk_prog5 天前
[Linux]学习笔记系列 -- [arm][debug]
linux·运维·arm开发·笔记·学习
皮蛋sol周5 天前
嵌入式学习硬件(一)ARM体系架构
arm开发·学习·架构
XINVRY-FPGA6 天前
XCZU19EG-2FFVB1517I FPGA Xilinx AMD ZynqUltraScale+ MPSoC
arm开发·嵌入式硬件·fpga开发·硬件架构·硬件工程·dsp开发·fpga