ARM AArch32和AArch64通用寄存器、状态寄存器_arm64 寄存器

T32(Thumb)状态下的寄存器组织

Thumb状态是ARM指令集的精简子集,旨在提升代码密度。其寄存器访问规则如下:

  • 低寄存器(R0-R7):可直接访问,无操作限制。
  • 高寄存器(R8-R15) :需通过特定指令(如MOVADDCMP)间接操作,通常用于临时数据或上下文切换。
  • 特殊寄存器
    • R13(SP):栈指针,维护函数调用栈。
    • R14(LR):链接寄存器,保存返回地址。
    • R15(PC):程序计数器,Thumb状态下指向当前指令地址+4(因流水线机制)。

AArch32关键寄存器解析

通用寄存器
  • R0-R12:通用数据寄存器。
  • R13(SP):每个异常模式(如IRQ、SVC)拥有独立栈指针,避免上下文保存开销。
  • R14(LR):保存函数或异常返回地址,AArch32中未完全分离异常与函数返回。
  • R15(PC):ARM状态读取值为当前指令+8,Thumb状态为+4。
状态与控制寄存器
  • CPSR:存储CPU模式(M4:0)、Thumb状态位(T)、中断标志等。
  • SPSR:异常发生时备份CPSR,不同模式(如IRQ、SVC)有独立副本。
  • VBAR/HVBAR:异常向量表基址寄存器,决定异常跳转目标。
  • ESR_ELx:记录异常原因(如EC字段区分指令/数据异常)。

AArch64寄存器体系改进

通用寄存器
  • X0-X30:64位通用寄存器,32位访问通过W0-W30。X30默认作为LR使用。
  • ELR_ELx:独立保存异常返回地址(如ELR_EL1),与函数返回地址分离。
栈与程序状态
  • SP_ELx :每个异常等级(EL0-EL3)拥有独立栈指针,通过SPSel选择使用模式。
  • PSTATE:替代CPSR,整合NZCV(条件标志)、DAIF(中断屏蔽)、CurrentEL(当前异常等级)。
中断与异常
  • DAIF:D/A/I/F位分别控制调试、SError、IRQ、FIQ的屏蔽状态。
  • CurrentEL:明确标识当前运行等级(如EL1为内核态)。

AArch32与AArch64核心差异

对比项 AArch32 AArch64
位宽 32位 64位
PC行为 ARM状态+8,Thumb+4 固定指向当前指令
异常模型 模式切换(如IRQ/SVC) 异常等级(EL0-EL3)
虚拟化支持 需扩展 原生集成

总结

AArch64通过统一寄存器设计、固定指令长度(32bit)和异常等级机制,显著优化了性能与安全性。现代系统(如Linux ARM64、Apple Silicon)均基于此架构,兼容性更强且更易优化。

编程语言C++www.dyhaofan.com++C语言的魅力

编程语言C++www.share.dyhaofan.com++C语言的魅力

编程语言C++share.dyhaofan.com++C语言的魅力

编程语言C++m.dyhaofan.com++C语言的魅力

编程语言C++www.blog.dyhaofan.com++C语言的魅力

编程语言C++read.share.dyhaofan.com++C语言的魅力

编程语言C++www.yekewu.com++C语言的魅力

编程语言C++www.share.yekewu.com++C语言的魅力

编程语言C++share.yekewu.com++C语言的魅力

编程语言C++m.yekewu.com++C语言的魅力

编程语言C++www.blog.yekewu.com++C语言的魅力

编程语言C++read.share.yekewu.com++C语言的魅力

编程语言C++www.niaoqiaj.com++C语言的魅力

编程语言C++www.share.niaoqiaj.com++C语言的魅力

编程语言C++share.niaoqiaj.com++C语言的魅力

编程语言C++m.niaoqiaj.com++C语言的魅力

编程语言C++www.blog.niaoqiaj.com++C语言的魅力

编程语言C++read.share.niaoqiaj.com++C语言的魅力

编程语言C++www.yaodianhuixiang.com++C语言的魅力

编程语言C++www.share.yaodianhuixiang.com++C语言的魅力

编程语言C++share.yaodianhuixiang.com++C语言的魅力

编程语言C++m.yaodianhuixiang.com++C语言的魅力

编程语言C++www.blog.yaodianhuixiang.com++C语言的魅力

编程语言C++read.share.yaodianhuixiang.com++C语言的魅力

编程语言C++www.huajinys.com++C语言的魅力

编程语言C++www.share.huajinys.com++C语言的魅力

编程语言C++share.huajinys.com++C语言的魅力

编程语言C++m.huajinys.com++C语言的魅力

编程语言C++www.blog.huajinys.com++C语言的魅力

编程语言C++read.share.huajinys.com++C语言的魅力

编程语言C++www.biodcn.com++C语言的魅力

编程语言C++www.share.biodcn.com++C语言的魅力

编程语言C++share.biodcn.com++C语言的魅力

编程语言C++m.biodcn.com++C语言的魅力

编程语言C++www.blog.biodcn.com++C语言的魅力

编程语言C++read.share.biodcn.com++C语言的魅力

相关推荐
WHS-_-20222 天前
When RDMA Meets Wireless
arm开发
szxinmai主板定制专家3 天前
基于 ARM+FPGA 数据机床实时工业控制设计--以雕刻机为例
arm开发·人工智能·嵌入式硬件·fpga开发
wandertp3 天前
对信号处理及滤波器的理解---基于robomaster机器人嵌入式控制系统
arm开发·stm32·算法·信号处理
XMAIPC_Robot3 天前
基于RK3588 ARM+FPGA电火花数控机床控制系统设计,兼顾ethercat软硬件实时
linux·arm开发·人工智能·嵌入式硬件·fpga开发
底层开发智库3 天前
C1-Ultra FVP调试并运行Linux kernel全程记录,硬核演示如何解决启动问题
linux·arm开发·内核·嵌入式·arm
XMAIPC_Robot3 天前
基于 ARM+FPGA 数据机床控制系统设计--以雕刻机为例
arm开发·fpga开发
一抹晴空3 天前
Keil MDK AC6 compiler编译报错,与AC5区别
c语言·arm开发·单片机
运维成长记3 天前
关于“有x86镜像,没有Dockerfile” 怎么制作arm架构的镜像
arm开发·架构
熠速4 天前
PolarBox高性能实时仿真系统
arm开发·fpga开发·嵌入式实时数据库·硬件在环半实物仿真
天下·第二5 天前
如何在【x86】服务器上打包构建【arm】镜像
服务器·arm开发·eureka