上篇文章:ARM 常见汇编指令学习 4 – ARM64 比较指令 cbnz 与 b.ne 区别
下篇文章:ARM 常见汇编指令学习 6 - bic(位清除), orr(位或), eor(异或)
ARM64 zero register
ARMv8 在硬件层名引入了一个新的 zero 寄存器:XZR(64-bits), WZR(32-bits)。比如要将某一变量赋值为0x0, 由于ARM不允许直接操作内存单元上的数据就,所以需要先将一个寄存器置0,然后再将这个寄存器的值store到内存单元上,如下:
ldr x1, =0x18ac0000
mov w0, #0
str w0, [x1, #0]
现在有有了zero 寄存器,那么一条指令就可以解决上面需要两条指令才能解决赋值0的问题:
str wzr, [x1, #0]

本文介绍了ARMv8架构中的零寄存器XZR和WZR,它们用于简化将变量赋值为0的操作。通过示例展示了如何在汇编代码中使用XZR进行读写操作,以及在位清除、位或和异或操作中的应用。

6714

被折叠的 条评论
为什么被折叠?



