Armv7的寄存器介绍

一、介绍

ARMv7 架构下核心寄存器分为通用寄存器、程序状态寄存器、专用寄存器三类,不同模式下部分寄存器有备份(banked),作用如下:

  1. 通用寄存器 (R0-R15)
  • R0-R7:未备份通用寄存器,所有处理器模式共享,用于临时数据存储、函数参数传递与返回值传递。

  • R8-R12:部分备份寄存器,FIQ 模式有独立备份(R8_fiq-R12_fiq),避免 FIQ 中断处理破坏原有数据。

  • R13 (SP):栈指针寄存器,各模式有独立备份,存放当前模式下栈顶地址。

  • R14 (LR):链接寄存器,各模式有独立备份,保存函数调用的返回地址或异常处理的返回地址。

  • R15 (PC):程序计数器,存储下一条要执行的指令地址,ARM 状态下指向当前指令 + 8 字节。

  1. 程序状态寄存器 (CPSR/SPSR)
  • CPSR:当前程序状态寄存器,记录 ALU 运算标志(N/Z/C/V)、中断屏蔽位(I/F)、处理器模式位(M4:0)等,所有模式共享。

  • SPSR:备份程序状态寄存器,仅异常模式拥有,用于保存进入异常前的 CPSR 值,异常返回时恢复 CPSR。

  1. 专用寄存器
  • 包括 CP15 协处理器寄存器(用于存储系统控制、内存管理、缓存配置等信息)、TPIDRPRW(线程 ID 寄存器)等,负责架构的底层控制与扩展功能。

二、不同模式下的寄存器

ARMv7 支User/System/IRQ/FIQ/SVC/Abort/Undefined 7 种模式,其中 User/System 为非异常模式,其余为异常模式,不同模式下寄存器的 banked(备份)情况不同,映射如下:

说明:

  1. System 模式与 User 模式寄存器完全相同,无 SPSR,用于运行特权级系统任务。

  1. FIQ 模式对 R8-R12 额外备份,目的是减少中断处理时的寄存器入栈开销,提升响应速度。

  1. 所有异常模式均有独立的 R13/R14 和 SPSR,避免异常处理破坏原模式的运行上下文
相关推荐
l'm coming1 天前
[linux]内核启动加载驱动文件的流程
linux·arm开发·驱动开发·嵌入式
Code-keys1 天前
ARM NEON SIMD 编程实战:从音频信号处理到AI算子研发实战
arm开发·音视频·信号处理
有什么事1 天前
云手机多开哪个强?ARM架构:云手机多开的信任基石与性能核心
arm开发·智能手机·架构
头枝1 天前
ARM Cortex-M DWT CYCCNT 必须显式初始化,jlink调试时正常,使用时异常的问题
arm开发·stm32·单片机·问题·cyccnt
咖喱年糕1 天前
KEIL5 编译错误解决:MDK 5.37 及以上版本添加 AC5(ARM Compiler 5)编译器
arm开发·单片机·keil·嵌入式软件·ac5
振南的单片机世界1 天前
中央对齐PWM:边沿对齐EMI大,中央对齐更安静
arm开发·stm32·单片机·嵌入式硬件
三佛科技-187366133971 天前
GD32F103VDT6是什么芯片?GD32 ARM Cortex-M3微控制器MCU解析
arm开发·单片机·嵌入式硬件
都在酒里1 天前
【极致低延时】香橙派部署 MediaMTX 实现 WebRTC 推流,延时仅 500-800ms,比局域网 ffmpeg 拉流快近 10 倍!(附踩坑全记录)
linux·arm开发·ffmpeg·webrtc·orangepi·嵌入式软件
XINVRY-FPGA2 天前
XC7A100T-2CSG324I AMD Xilinx Artix-7 FPGA
arm开发·人工智能·嵌入式硬件·神经网络·fpga开发·硬件工程·fpga
拼搏的小浣熊2 天前
香橙派Zero3的奇幻之旅【【持续更新】香橙派zero3从入门到玩转 各种工具+笔记】
arm开发·物联网·香橙派