news 2026/5/5 19:36:50

Armv7的寄存器介绍

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Armv7的寄存器介绍

一、介绍

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

1. 通用寄存器 (R0-R15)

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

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

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

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

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

2. 程序状态寄存器 (CPSR/SPSR)

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

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

3. 专用寄存器

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

二、不同模式下的寄存器

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

说明:

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

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

3. 所有异常模式均有独立的 R13/R14 和 SPSR,避免异常处理破坏原模式的运行上下文

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 11:48:04

SVNAdmin2完全攻略:Web版SVN管理系统的革命性突破

SVNAdmin2完全攻略:Web版SVN管理系统的革命性突破 【免费下载链接】SvnAdminV2.0 基于web的SVN管理系统,支持HTTP协议、SVN协议、支持LDAP认证、Docker部署 项目地址: https://gitcode.com/gh_mirrors/sv/SvnAdminV2.0 SVNAdmin2作为一款创新的We…

作者头像 李华
网站建设 2026/4/29 21:22:12

系统优化:Windows系统隐私防护的实用工具推荐(附下载)

软件获取地址 WPD系统隐私优化工具 一、为什么需要关注Windows隐私? 当你在Word里敲下客户资料,操作系统可能已将你的输入习惯传回微软服务器;当Cortana用甜美女声播报天气,你的语音数据有可能已被打上“可商用”标签&#xff1…

作者头像 李华
网站建设 2026/5/5 3:00:15

终极指南:嵌入式设备异步OTA更新的革命性突破

终极指南:嵌入式设备异步OTA更新的革命性突破 【免费下载链接】AsyncElegantOTA Deprecated: Perform OTAs for ESP8266 / ESP32 Elegantly! Uses AsyncWebServer 项目地址: https://gitcode.com/gh_mirrors/as/AsyncElegantOTA 在物联网技术飞速发展的今天&…

作者头像 李华
网站建设 2026/4/23 9:48:17

DeepKE-LLM实战指南:5步掌握大模型知识抽取核心技术

DeepKE-LLM实战指南:5步掌握大模型知识抽取核心技术 【免费下载链接】DeepKE An Open Toolkit for Knowledge Graph Extraction and Construction published at EMNLP2022 System Demonstrations. 项目地址: https://gitcode.com/gh_mirrors/de/DeepKE 还在为…

作者头像 李华
网站建设 2026/5/5 3:37:01

Python背景移除终极指南:remove-bg完整使用教程

Python背景移除终极指南:remove-bg完整使用教程 【免费下载链接】remove-bg A Python API wrapper for removing background using remove.bgs API 项目地址: https://gitcode.com/gh_mirrors/re/remove-bg 还在为复杂的图片背景处理而烦恼吗?今天…

作者头像 李华
网站建设 2026/4/24 16:52:57

ESP32音频革命:P3专有格式的终极指南与实战技巧

ESP32音频革命:P3专有格式的终极指南与实战技巧 【免费下载链接】xiaozhi-esp32 Build your own AI friend 项目地址: https://gitcode.com/GitHub_Trending/xia/xiaozhi-esp32 想象一下,你正为智能音箱项目苦恼:语音交互卡顿、存储空…

作者头像 李华