【ARM 常见汇编指令学习 5 -- arm64汇编指令 wzr 和 xzr】

news/2024/7/1 5:18:08

文章目录

    • ARM64 zero register
      • ARMv8 zero 寄存器的背景
      • xzr 在寄存器读写操作中的使用

上篇文章: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 zero 寄存器的背景

我们知道ARMv8 通用寄存器是X0-X29一共30个,其中X30为链接寄存器,那么X31呢
一般都是知道X31是栈指针寄存器,其实X31的另外一个作用就是zero 寄存器, 那么如何保证两者在使用时不冲突呢
这就是在写汇编代码时需要注意的地方,如果某条指令使用SP寄存,那么这条指令就不能再使用xzr/wzr寄存器了。

xzr 在寄存器读写操作中的使用

ldr x7, =0x18bc0100
mov x8, xzr
ldr w9, =0xffffff00
ldr w8, [x7, #0x3c]
and w8, w8, w9
str w8, [x7, #0x3c]
dsb sy
isb

上面这段汇编对应C代码为:

uint32_t addr = 0x18bc0100;
uint32_t val = 0x0;

val = read32(addr + 0x3c);
val &= 0xffffff00;
write32(val, addr + 0x3c);

下面这段汇编代码使用了bic 位清除 指令。

ldr x7, =0x18bc0100
mov x8, xzr
ldr w8, [x7, #0x8]
bic w8, w8, #(1<<4)
str w8, [x7, #0x8]
dsb sy
isb

对应的 C code 如下:

uint32_t addr = 0x18bc0100;
uint32_t val = 0x0;

val = read32(addr + 0x8);
val &= ~(0x1 << 4);
write32(val, addr + 0x8);

关于 bic(位清除)、orr(位或)、eor (异或)具体使用请见下篇文章。

上篇文章:ARM 常见汇编指令学习 4 – ARM64 比较指令 cbnz 与 b.ne 区别
下篇文章:ARM 常见汇编指令学习 6 - bic(位清除), orr(位或), eor(异或)


http://lihuaxi.xjx100.cn/news/1386466.html

相关文章

二叉树的层序遍历(两种方法:迭代+递归)

题目&#xff1a; 给你二叉树的根节点 root &#xff0c;返回其节点值的 层序遍历 。 &#xff08;即逐层地&#xff0c;从左到右访问所有节点&#xff09;。 输入&#xff1a;root [3,9,20,null,null,15,7] 输出&#xff1a;[[3],[9,20],[15,7]] 解题思路&#xff1a;迭代法…

小狐狸ChatGPT付费创作系统V2.1.0全开源版(vue全端)

小狐狸GPT付费体验系统最新版系统是一款基于ThinkPHP框架开发的AI问答小程序&#xff0c;是基于国外很火的ChatGPT进行开发的Ai智能问答小程序。当前全民热议ChatGPT&#xff0c;流量超级大&#xff0c;引流不要太简单&#xff01;一键下单即可拥有自己的GPT&#xff01;无限多…

SAP财务系统中的“增值税”

1. 前言 在前一篇博客《SAP财务系统中的“复式记账法”》中&#xff0c;介绍了复式记账的基本原理&#xff0c;同时给出了在采购和销售流程中常见的记账科目&#xff0c;但也遗留了一些知识点&#xff0c;例如增值税等概念。 在本篇博客中&#xff0c;我们将覆盖这些知识点&a…

Python版day60

84. 柱状图中最大的矩形 给定 n 个非负整数&#xff0c;用来表示柱状图中各个柱子的高度。每个柱子彼此相邻&#xff0c;且宽度为 1 。 求在该柱状图中&#xff0c;能够勾勒出来的矩形的最大面积。 class Solution:def largestRectangleArea(self, heights: List[int]) -> i…

简单动态库调用CMakeLists配置

1. 动态库生成 fun.h和fun.cpp int my_add(int a, int b); #include "fun.h" int my_add(int a, int b) {return a b; } 动态库生成的CMakeLists.txt cmake_minimum_required(VERSION 3.14) set(CMAKE_DEBUG_POSTFIX "d") project(funso) set(SRC_ f…

const的用法

目录 const的基本理解 C和C中const的区别 代码段 不初始化or初始化 常变量or常量 编译方式 备注开发环境&#xff1a;vscode通过ssh连接虚拟机中的ubuntu&#xff0c;ubuntu-20.04.3-desktop-amd64.iso const的基本理解 const修饰的变量不能作为左值 const修饰的变量初…

信息安全战线左移!智能网联汽车安全亟需“治未病”

当汽车由典型的工业机械产品逐步发展成为全新的智能移动终端&#xff0c;汽车的安全边界发生了根本性改变&#xff0c;信息安全风险和挑战不断增加。 面对复杂的异构网络、异构系统及车规级特异性要求&#xff0c;智能智能网联汽车信息安全到底要如何防护&#xff0c;已经成为…

kotlin学习和常用知识

目录 一、Kotlin 详解二、Kotlin 发展历史三、Kotlin 的特性四、案列 Kotlin 是一种由 JetBrains 公司开发的静态类型编程语言&#xff0c;旨在为 Java 开发者提供一种更加安全、简洁、易于使用的编程语言。Kotlin 可以编译成 Java 字节码&#xff0c;因此可以在 Java 虚拟机&a…