ARM 寄存器

文章目录

    • ARM 寄存器介绍
      • 一、未分组寄存器 R0~R7
      • 二、分组寄存器 R8~R14
      • 三、程序计数寄存器 R15(PC)
      • 四、当前程序状态寄存器 R16(CPSR)
        • 管理模式(SVC)
        • 用户模式(USR)
    • 汇编里的寄存器名称
      • ATPCS
      • 寄存器的使用规则

ARM 寄存器介绍

Cortex A 系列的 ARM 处理器共有 40 个 32 位寄存器,其中 33 个为通用寄存器,7 个为状态寄存器。用户模式和系统模式共用同一组寄存器。
在这里插入图片描述

一、未分组寄存器 R0~R7

有些寄存器是所有运行模式共用的,如 R0~R7,它们被称为未分组寄存器。
在所有运行模式下,未分组寄存器都指向同一个物理寄存器,它们未被系统用作特殊用途。
在运行模式转换时,不同运行模式的处理器均使用相同的物理寄存器,可能造成寄存器中数据的覆盖。

二、分组寄存器 R8~R14

分组寄存器每一次访问的物理寄存器都与当前处理器的运行模式有关。
对 R8~R12 来说,每个寄存器对应 2 个不同的物理寄存器。当使用快速中断模式时,分组寄存器访问寄存器 R8_fiq ~ R12_fiq;当使用除快速中断模式以外的其他模式时,分组寄存器访问寄存器 R8_usr ~ R12_usr。
对 R13、R14 来说,每个寄存器对应 7 个不同的物理寄存器,其中一个为用户模式和系统模式共用,另外 6 个物理寄存器对应其它 6 种不同的运行模式,并采用以下记号来区分不同的物理寄存器。

R13_mode、R14_mode
其中 mode 可为 usr、fiq、irq、svc、abt、und、mon

① 寄存器 R13(SP)
寄存器 R13 在 ARM 指令集中常被用作堆栈指针,用户也可以使用其它寄存器作为堆栈指针,而在 Thumb 指令集中,某些指令强制要求使用寄存器 R13 作为堆栈指针。
处理器的每种运行模式均有自己独立的物理寄存器 R13,在用户应用程序初始化时,要初始化每种运行模式下的 R13 寄存器,使其指向该运行模式的栈空间。这样,当程序的运行进入异常模式时,可以将需要保护的寄存器中的数据保存至 R13 所指向的堆栈,而当程序从异常模式返回时,再从该堆栈中恢复数据,采用这种方式可以保证异常发生后程序也能正常执行。

② 寄存器 R14(LR)
当执行子程序调用指令(BL)时,R14 可得到 R15(程序计数器)的备份。
在每一种运行模式下,都可用 R14 保存子程序的返回地址,当用指令 BL 或 BLX 调用子程序时,将程序计数器的当前值复制给 R14,执行完子程序后,又将 R14 的值复制回程序计数器,即可完成子程序的调用返回。

三、程序计数寄存器 R15(PC)

寄存器 R15 用作程序计数器,在 ARM 状态下,bit[1:0] 为 0,bit[31:2] 用于保存 PC 值,在 Thumb 状态下,bit[0] 为 0,bit[31:1] 用于保存 PC 值。
例如,在 ARM 状态下,如果 PC 的值是 0x40008001,那么在寻址时,查找的地址为 0x40008000,低 2 位会自动被忽略掉。

四、当前程序状态寄存器 R16(CPSR)

ARM 包含一个当前程序状态寄存器 CPSR(R16)(Current Program Status Register)和 6 个备份的程序状态寄存器(SPSRs)。CPSR 在任何工作模式都可被访问,用来保存 ALU 中的当前操作信息、控制允许和禁止中断、设置处理器的工作模式等。
在这里插入图片描述

其中工作模式位(M[4:0])用来标识或设置处理器的工作模式。
在这里插入图片描述

下面,我们通过调试,看下管理模式和用户模式下 CPSR 的值,实际感受下

管理模式(SVC)

在这里插入图片描述
在内核代码中打上断点,断点命中后,CPU 停止运行,此时 cpsr 寄存器的值为 0x60000193,我们只看最低 5 bits,值为 10011b,对应上表中的 SVC 管理模式。
PS:Linux 内核代码大多数时候都是以 SVC 管理模式运行的,其中,软中断相关的调用是使用 SYS 系统模式运行的。而且,内核在特定的情况下可以主动从 SVC 模式切换到 SYS 模式去运行。

用户模式(USR)

在这里插入图片描述
在用户进程的 main 函数打上断点,断点命中后,CPU 停止运行,此时 cpsr 寄存器的值为 0x60080010,最低 5 bits 为 10000b,对应上表中的用户模式。

汇编里的寄存器名称

我们在看反汇编代码时,常常会看到 fp、lr 等寄存器名称,这些是指什么呢?

liyongjun@Box:~/project/board/buildroot/override/Vexpress_2/test$ /home/liyongjun/project/board/buildroot/Vexpress_2/host/bin/arm-linux-objdump -d test.out 
...
000005b8 <main>:5b8:	e92d4800 	push	{fp, lr}5bc:	e28db004 	add	fp, sp, #45c0:	e24dd008 	sub	sp, sp, #85c4:	e3a03000 	mov	r3, #05c8:	e50b3008 	str	r3, [fp, #-8]5cc:	ea000008 	b	5f4 <main+0x3c>5d0:	e59f3038 	ldr	r3, [pc, #56]	@ 610 <main+0x58>5d4:	e08f3003 	add	r3, pc, r35d8:	e1a00003 	mov	r0, r35dc:	ebffff92 	bl	42c <puts@plt>5e0:	e3a00001 	mov	r0, #15e4:	ebffff8d 	bl	420 <sleep@plt>5e8:	e51b3008 	ldr	r3, [fp, #-8]5ec:	e2833001 	add	r3, r3, #15f0:	e50b3008 	str	r3, [fp, #-8]5f4:	e51b3008 	ldr	r3, [fp, #-8]5f8:	e3530009 	cmp	r3, #95fc:	dafffff3 	ble	5d0 <main+0x18>600:	e3a03000 	mov	r3, #0604:	e1a00003 	mov	r0, r3608:	e24bd004 	sub	sp, fp, #460c:	e8bd8800 	pop	{fp, pc}610:	000000d4 	.word	0x000000d4
...

在解答疑问之前,我们先介绍一个概念:ATPCS

ATPCS

ATPCS(ARM-Thumb Produce Call Standard)是 ARM 程序和 Thumb 程序中调用的基本规则。这些基本规则包括子程序调用过程中寄存器的使用规则,数据栈的使用规则,参数的传递规则。

寄存器的使用规则

下表总结了在 ATPCS 中各寄存器的使用规则及其名称。这些名称在编译器和汇编器中都是预定义的。
在这里插入图片描述
寄存器的使用必须满足下面的规则。

  • 子程序间通过寄存器 R0~R3 来传递参数。这时,寄存器 R0~R3 可以记作 A0~A3。
  • 在子程序中使用寄存器 R4~R11 来保存局部变量。这时,寄存器 R4~R11 可以记作 V1~V8。如果在子程序中也使用到了寄存器 V1~V8,那么子程序进入时必须保存这些寄存器的值,在返回前必须恢复这些寄存器的值。
  • 寄存器 R12 用作子程序间 scratch 寄存器,记作 IP,在子程序间的连接代码段中常有这种使用规则。
  • 寄存器 R13 用作堆栈指针,记作 SP,在子程序中寄存器 R13 不能用作其它用途。寄存器 SP 在进入子程序时的值和退出子程序时的值必须相等。
  • 寄存器 R14 称为连接寄存器,记作 LR。它用于保存子程序的返回地址。如果在子程序中保存了返回地址,寄存器 R14 则可以用作其它用途。
  • 寄存器 R15 是程序计数器,记作 PC。他不能用作其他用途。

通过以上介绍,我们就知道了 fp、lr 分别是寄存器 R11、R14 的别名。类似的寄存器别名还有 pc、sp、ip、sl 等。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/614620.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

YOLOv8-Seg改进:轻量化改进 | MobileNetV3,轻量级骨架首选

🚀🚀🚀本文改进:MobileNetV3的创新点包括:使用自适应瓶颈宽度、借鉴SENet中的Squeeze-and-Excitation机制、引入h-swish激活函数等。 🚀🚀🚀YOLOv8-seg创新专栏:http://t.csdnimg.cn/KLSdv 学姐带你学习YOLOv8,从入门到创新,轻轻松松搞定科研; 1)手把手教…

JVM 元空间、java中的元空间

JVM 元空间 元空间 元空间 原空间&#xff08;Meta Space&#xff09; ​ 用于存放类信息、常量、静态变量、JIT即时编译器百年以后的机器代码等数据等。例如&#xff1a;java.lang.Object类的元信息、Integer.MAX_VALUE等常量。 JDK1.6 HotSpot JVM 使用Method Area方法区存…

植物大战僵尸-C语言搭建童年游戏(easyx)

游戏索引 游戏名称&#xff1a;植物大战僵尸 游戏介绍&#xff1a; 本游戏是在B站博主<程序员Rock>的视频指导下完成 想学的更详细的小伙伴可以移步到<程序员Rock>视频 语言项目&#xff1a;完整版植物大战僵尸&#xff01;可能是B站最好的植物大战僵尸教程了&…

Jenkins基础篇--凭据(Credential)管理

什么是凭据 Jenkins的Credentials直译为证书、文凭&#xff0c;我们可以理解为它是钥匙&#xff0c;用来做某些事情的认证。 如Jenkins 和 GitLab交互时&#xff0c;需要添加GitLab的API令牌和登录凭证。 如Jenkins 添加从节点时&#xff0c;需要添加从节点的登录凭证或者Je…

Jenkins基础篇--添加用户和用户权限设置

添加用户 点击系统管理&#xff0c;点击管理用户&#xff0c;然后点击创建用户&#xff08;Create User&#xff09; 用户权限管理 点击系统管理&#xff0c;点击全局安全配置&#xff0c;找到授权策略&#xff0c;选择安全矩阵&#xff0c;配置好用户权限后&#xff0c;点击…

Redis内存分析工具

Redis内存分析工具RDR 了解一下RDR的优势 1&#xff0c;首先RDR工具是图形化界面&#xff0c;能非常直观的就能看到内存主键分布 2&#xff0c;可以快速分析 Redis 内存中那个 Key 值占用的内存最大 启动 ./rdr-linux show -p 8080 /usr/local/redis-5.0.3/data/dump.rdb st…

线索系统性能优化实践

引言 在京东家居事业部&#xff0c;线索CRM系统扮演着至关重要的角色&#xff0c;它作为构建家居场景核心解决方案集的首要环节&#xff0c;肩负着获客和拓展业务的重要使命。然而&#xff0c;随着业务的不断扩张和市场需求的日益增长&#xff0c;系统原有的架构开始显露出诸多…

使用图形化界面工具DataGrip

目录 添加数据源 展示所有数据库 创建数据库 创建表 修改表结构 在DataGrip中执行SQL语句 &#x1f389;欢迎您来到我的MySQL基础复习专栏 ☆* o(≧▽≦)o *☆哈喽~我是小小恶斯法克&#x1f379; ✨博客主页&#xff1a;小小恶斯法克的博客 &#x1f388;该系列文章专栏&am…

构建基于RHEL9系列(CentOS9,AlmaLinux9,RockyLinux9等)的Nginx1.24.0的RPM包

本文适用&#xff1a;rhel9系列&#xff0c;或同类系统(CentOS9,AlmaLinux9,RockyLinux9等) 文档形成时期&#xff1a;2023年 因系统版本不同&#xff0c;构建部署应略有差异&#xff0c;但本文未做细分&#xff0c;对稍有经验者应不存在明显障碍。 因软件世界之复杂和个人能力…

使用Flash_Download_Tool下载PlatformIO生成的bin程序到ESP32

使用Flash_Download_Tool下载PlatformIO生成的bin程序到ESP32 来源 当我们没有PlatformIO环境时&#xff0c;还要下载PlatformIO生成的程序时&#xff0c;可以使用Flash_Download_Tool工具下载。 说明 使用PlatformIO时&#xff0c;用cmd终端命令下载程序pio run -v -t upl…

2023 IoTDB Summit:天谋科技高级开发工程师张金瑞《筑其形:如何轻松搞定 IoTDB 数据建模》...

12 月 3 日&#xff0c;2023 IoTDB 用户大会在北京成功举行&#xff0c;收获强烈反响。本次峰会汇集了超 20 位大咖嘉宾带来工业互联网行业、技术、应用方向的精彩议题&#xff0c;多位学术泰斗、企业代表、开发者&#xff0c;深度分享了工业物联网时序数据库 IoTDB 的技术创新…

CSS中用border画三角形等图形

问题背景 最近在做一个官网项目的时候&#xff0c;UI小姐姐设计了一些特殊图形&#xff0c;例如三角形&#xff0c;虽然element-ui是带有相应模板的&#xff0c;但是设计的和模版的不一样&#xff0c;因此研究了一下。 三角形怎么画 三角形实际上是border的产物 我们正常使用…

SpringBoot 把PageHelper分页信息返回给前端

第1步&#xff1a;定义线程容器收纳HttpHeaders和HttpStatus import org.springframework.http.HttpHeaders; import org.springframework.http.HttpStatus;public class ResponseUtils {private static ThreadLocal<HttpHeaders> ThreadLocalHeaders new InheritableT…

Window平台安装MongoDB

在部署前需要在官网先确定系统对应的Mongo DB版本。 本机电脑为Window10&#xff0c;所以这里以MongoDB 6.0版本。 1 在官网下载安装包 2 安装MongoDB MongoDB Compass 是一个图形界面管理工具&#xff0c;如果勾选了安装会花费长一点时间&#xff0c;可以取消掉勾选&#xff…

构建基于RHEL8系列(CentOS8,AlmaLinux8,RockyLinux8等)的Nginx1.24.0的RPM包

本文适用&#xff1a;rhel8系列&#xff0c;或同类系统(CentOS8,AlmaLinux8,RockyLinux8等) 文档形成时期&#xff1a;2022-2023年 因系统版本不同&#xff0c;构建部署应略有差异&#xff0c;但本文未做细分&#xff0c;对稍有经验者应不存在明显障碍。 因软件世界之复杂和个人…

Dockerfile: CMD与ENTRYPOINT区别

CMD和ENTRYPOINT的作用 CMD和ENTRYPOINT这两个命令&#xff0c;我接触到的是用在了Dockerfile中用于构建容器。 CMD&#xff1a;The main purpose of a CMD is to provide defaults for an executing container. CMD的主要用途是为正在执行的容器提供默认值。也就是指定这个容…

web前端算法简介之栈

栈 栈的基本操作包括&#xff1a; 初始化栈&#xff08;InitStack&#xff09;&#xff1a;判断栈是否为空&#xff08;IsStackEmpty&#xff09;&#xff1a;入栈&#xff08;Push&#xff09;&#xff1a;出栈&#xff08;Pop&#xff09;&#xff1a;获取栈顶元素&#xff0…

如何将ArcGIS工程文件迁移到ArcGIS Pro内

当你刚接触ArcGIS Pro的时候&#xff0c;尝试新建一个工程文件会发现工程文件的后缀已经改变&#xff0c;那么以前在ArcGIS内辛苦制作的工程文件是否就不能在ArcGIS Pro内使用了&#xff0c;答案是否定的&#xff0c;对此Esri也给出了解决方案&#xff0c;这里为大家介绍一下迁…

Docker数据持久化

数据持久化 在容器层的 UnionFS&#xff08;联合文件系统&#xff09;中对文件/目录的任何修改&#xff0c;无论是手工修改还是 容器在运行过程中的修改&#xff0c;在该容器丢失或被删除后这些修改将全部丢失。即这些修改是无 法保存下来的。若要保存下来这些修改&#xff0c;…

如何一键添加引号和英文逗号,然后可以放入SQL中使用 → WHERE USER_NAME IN (‘张三‘,‘李四‘,‘王五‘)

如何一键添加引号和英文逗号&#xff0c;然后可以放入SQL中使用 → WHERE USER_NAME IN&#xff08;张三,李四,王五&#xff09; 一、背景二、解决方法三、一键添加引号和英文逗号的教程 一、背景 在日常开发中&#xff0c;当处理VARCHAR或VARCHAR2类型的字段时&#xff0c;很…