ARMv8架构特殊寄存器介绍-0

一、zero 寄存器

复制代码
零寄存器用作源寄存器时读取零,用作目标寄存器时丢弃结果。您可以在大多数指令中使用零寄存器,但不是所有指令。

二、sp寄存器

复制代码
在ARMv8架构中,要使用的堆栈指针的选择在某种程度上与Exception级别。默认情况下,异常为目标选择堆栈指针异常级别,SP_ELn。例如,对EL1采取异常将选择SP_EL1。每一个异常级别有自己的堆栈指针,SP_EL0、SP_EL1、SP_EL2和SP_EL3。

当在AArch64中处于EL0以外的异常级别时,处理器可以使用:
  • 与异常级别(SP_ELn)相关联的专用64位堆栈指针。

  • 与EL0 (SP_EL0)相关的堆栈指针。

    EL0只能访问SP_EL0。

    后缀"t"表示选择SP_EL0堆栈指针。h后缀表示SP_ELn堆栈指针被选中。SP不能被大多数指令引用。然而,某些形式的算术指令,例如ADD指令,可以对当前栈指针进行读写调整函数中的堆栈指针。

bash 复制代码
	例如:
	ADD SP, SP, #0x10 //将SP调整为当前值之前的0x10字节

三、Program Counter寄存器(PC)

原始ARMv7指令集的一个特点是使用了R15,即程序计数器(PC)作为通用寄存器。个人电脑实现了一些聪明的编程技巧,但它介绍了编译器的复杂性和复杂管道的设计。直接删除在ARMv8中访问PC使返回预测更容易,并简化了ABI规范。

PC永远不能作为命名寄存器访问。它的用法隐含在某些指令中,例如与pc相关的负载和地址生成。不能将PC指定为数据的目的地处理指令或加载指令。

相关推荐
y***613122 分钟前
【Linux系统】计算机世界的基石:冯诺依曼架构与操作系统设计
架构
七夜zippoe1 小时前
昇腾AI计算架构的基石 - 深度剖析CANN与Ascend C
架构·昇腾·cann·ascend c·pow
小毅&Nora1 小时前
【后端】蓝绿发布全链路改造详解:从配置到生产环境的完整实践
架构·持续部署
智元视界1 小时前
从深度学习到自主学习:AI的下一个技术跃迁
大数据·人工智能·深度学习·学习·架构·数字化转型·产业升级
6269601 小时前
微服务负载均衡导致新增的字段时有时无的问题排查与解决/(ㄒoㄒ)/~~
微服务·架构·负载均衡
刘一说1 小时前
Nacos 配置加载优先级详解:Spring Cloud Alibaba 微服务配置管理的核心机制
微服务·云原生·架构
曾经的三心草1 小时前
微服务的编程测评系统-linux部署指令
linux·微服务·架构
v***44671 小时前
【语义分割】12个主流算法架构介绍、数据集推荐、总结、挑战和未来发展
算法·架构
l***91472 小时前
电池管理系统(BMS)架构详细解析:原理与器件选型指南
架构
ChrisitineTX2 小时前
万字硬核拆解:Gemini 3.0 架构革新,多模态原生模型的天花板被捅破了?(1)
人工智能·架构