ARM 处理器拥有 37 个寄存器。 这些寄存器按部分重叠组方式加以排列。 每个处理器模式都有一个不同的寄存器组。 编组的寄存器为处理处理器异常和特权操作提供了快速的上下文切换。

提供了下列寄存器:三十个 32 位通用寄存器、程序计数器 (pc)、应用程序状态寄存器 (APSR)、保存的程序状态寄存器 (SPSR)

  • 三十个 32 位通用寄存器

在任一时刻都存在十五个通用寄存器,它们分别是 r0-r12、sp、lr。
sp (或 r13)是堆栈指针。 C 和 C++ 编译器始终将 sp 用作堆栈指针。 建议您不要将 sp 用作通用寄存器。
在用户模式下, lr (或 r14)用作链接寄存器 (lr),用于存储调用子例程时的返回地址。 如果返回地址存储在堆栈上,则也可将 r14 用作通用寄存器。
在异常处理模式下, lr 存放异常的返回地址;如果在一个异常内执行了子例程调用,则 lr 存放子例程的返回地址。如果返回地址存储在堆栈上,则可将 lr 用作通用寄存器。

其中:未备份寄存器(The unbanked registers) , R0~R7。当处理器模式切换时, 未备份寄存器指的是同一个物理寄存器, 所有可能造成寄存器中数据被破坏. 
备份寄存器(The banked registers) , R8~R14。

对于R8~R12, 每个寄存器对应2个不同的物理寄存器。如:快速模式下,R8对应R8_fiq;用户模式下,R8对应R8_usr. 这两种情况下, 使用的是不同的物理寄存器. 
对于R13,R14, 每个寄存器对应6个不同的物理寄存器。其中用户模式和系统模式下是共用一个物理寄存器。其它5种处理器模式分别使用: R13_<mode>, R14_<mode>来表式. 
R13在ARM中常用作栈指针. 每一种异常模式拥有自己的物理R13. 应用程序去初始化该R13, 使其指向该异常模式专用的栈地址. 
R14又称连接寄存器(Link Register, LR), 在ARM中有以下2个作用
1) 每种模式有自己的物理R14,  存放当前子程序的返回地址.  当通过BL或BLX指令调用子程序时, R14被设置成该子程序的返回地址.  子程序中, 当把R14的值复制到程序计数器PC中时, 子程序返回.

例: 
MOV PC , LR    #把R14的值复制到程序计数器PC中
BX LR             #
STMFD SP! , { <registers>,LR }   #在子程序入口将PC保存到栈中
LDMFD SP!, { <registers>,PC }    #子程序返回

2) 异常中断发生时, 该异常模式特定的物理R14被设置成该异常模式将要返回的地址.

  • 程序计数器 (pc)

程序计数器被当作 pc (或 r15)进行访问。 在 ARM 状态下,它对每个指令以一个字(四字节)为增量递增,在 Thumb 状态下则按所执行指令的大小递增。 跳转指令将目标地址加载到 pc 中。 您也可以使用数据操作指令来直接加载 PC。
例如,若要从子例程返回,可以使用以下指令将链接寄存器复制到 PC 中:
MOV pc,lr
在执行期间, pc 不包含当前执行的指令的地址。 在 ARM 状态下,当前执行的指令的地址通常是 pc–8,而在 Thumb 状态下通常是 pc–4。

  • 应用程序状态寄存器 (APSR)

APSR 存放算术逻辑单元 (ALU) 状态标记的副本。 这些标记用于确定是否执行条件指令。可在所有模式下使用 MSR 和 MRS 指令访问这些标记。

  • 当前程序状态寄存器 (CPSR)

CPSR 存放下列内容:
• APSR 标记
• 当前处理器模式
• 中断禁用标记
• 当前处理器状态(ARM、Thumb、ThumbEE 或 Jazelle)
• IT 块的执行状态位
执行状态位控制 IT 块中的条件执行(请参阅第4-114 页的IT),并且仅可用于ARMv6T2 及更高版本。
在所有模式下均可访问的标记只有 APSR 标记。 对于 CPSR 的其余位,只能在特权模式下使用 MSR 和 MRS 指令访问它们。

  • 保存的程序状态寄存器 (SPSR)

当发生异常时,使用 SPSR 来存储 CPSR。 在每种异常处理模式下,可访问一个SPSR。 用户模式和系统模式没有 SPSR,因为二者不是异常处理模式。

arm寄存器的更多相关文章

  1. ARM寄存器学习,王明学learn

    ARM寄存器学习 ARM微处理器共有37个32位寄存器,其中31个为通用寄存器,6个为状态寄存器.但是这些寄存器不能被同时访问,具体哪些寄存器是可以访问的,取决ARM处理器的工作状态及具体的运行模式. ...

  2. ARM 寄存器的介绍

    ARM  寄存器  31个通用, 32个程序状态寄存器 怎么算的呢: (R0--R15)   16  +  7 + 8  =31 通用 程序状态寄存器:    6 个 共  37 个. 不分组寄存器: ...

  3. R0-R37它是Arm 寄存器,那是,CPU内部。和GPIO注册所有外设。换句话说,要是arm的cpu,它包含了其他芯片公司将有R0-R37,和GPIO寄存器只有一个特定的芯片。

    R0-R37它是Arm 寄存器.那是,CPU内部.和GPIO注册所有外设. 换句话说,要是arm的cpu,它包含了其他芯片公司将有R0-R37,和GPIO有. 版权声明:本文博主原创文章.博客,未经同 ...

  4. 【嵌入式开发】ARM 芯片简介 (ARM芯片类型 | ARM处理器工作模式 | ARM 寄存器 | ARM 寻址)

    : 12MHz 晶振 对应 405 ~ 532 MHz 处理速度; -- : 16K 指令缓存, 16K 数据缓存; -- : 32KB 指令缓存, 32KB 数据缓存; (3) 内存接口对比 : 提 ...

  5. ARM寄存器介绍

    ARM处理器共有37个寄存器.其中包括:31个通用寄存器,包括程序计数器(PC)在内.这些寄存器都是32位寄存器.以及6个32位状态寄存器.但目前只使用了其中12位.ARM处理器共有7种不同的处理器模 ...

  6. ARM 寄存器

    ARM总共有37个寄存器 ARM寄存器物理分类 通用寄存器:1:不分组寄存器(R0--R7) 2:分组寄存器(R8-R14) 3:程序计数器(R15)(注意:又名pc指针) 程序状态寄存器:1:CPS ...

  7. Arm寄存器介绍及汇编基础

    一.ARM处理器支持7种工作模式 ① 用户模式(USR): 用于正常执行程序(The normal ARM program execution state) ② 快速中断模式(FIQ): 用于高速数据 ...

  8. arm寄存器解析

    寒假闲来无事准备将自己的走过的arm之路总结一下,今天就先从arm的寄存器说起吧,欢迎各位拍砖. 要介绍arm寄存器之前我们要先了解一下arm处理器的工作模式: Arm处理器有七种工作模式,为的是形成 ...

  9. ARM 寄存器 和 工作模式了解

    一. ARM 工作模式 1.   ARM7,ARM9,ARM11,处理器有 7 种工作模式:Cortex-A 多了一个监视模式(Monitor) 2.  用户模式:非特权模式,大部分任务执行在这种模式 ...

  10. 小议ARM寄存器

    ARM微处理器一共有37个32位寄存器,其中包括31个通用寄存器和6个状态寄存器,但是这些寄存处不能同时访问.但是通用寄存器R14 - R0 ,程序计数器PC(即R15),程序状态寄存器都是可以任何时 ...

随机推荐

  1. git几个必知托管平台

      程序员必须知道的几个Git代码托管平台 说到Git代码托管平台,首先推荐的是GitHub,好多好的开源项目都来自GitHub,但是GitHub只能新建公开的Git仓库,私有 仓库要收费,如果你做的 ...

  2. SqlMapConfig.xml 的配置

    jdbc.properties :数据库连接的配置 jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://192.168.181.135:33 ...

  3. Spring MVC 使用介绍(十四)文件上传下载

    一.概述 文件上传时,http请求头Content-Type须为multipart/form-data,有两种实现方式: 1.基于FormData对象,该方式简单灵活 2.基于<form> ...

  4. Plctext 如何发送默认的模式

    当切屏指令都没有的情况下,就会发,即:当65这个地址位(0-7),都为零的情况下.

  5. Codeforces Round #523 (Div. 2) D. TV Shows 模拟(多重集 先把所有区间加入多重集合)+贪心+二分

    题意:给出n个电视节目的起始和结束时间  并且租一台电视需要x +y*(b-a)  [a,b]为时段 问完整看完电视节目的最小花费是多少 思路:贪心的思想 情况1 如果新租一台电视的花费<=在空 ...

  6. mybatis-generator自动生成代码插件

    mybatis自动生成代码(实体类.Dao接口等)是很成熟的了,就是使用mybatis-generator插件. 它是一个开源的插件,使用maven构建最好,可以很方便的执行 插件官方简介: http ...

  7. Phython中读写和存储.mat文件

    背景 在做deeplearning过程中,使用caffe的框架,一般使用matlab来处理图片(matlab处理图片相对简单,高效),用python来生成需要的lmdb文件以及做test产生结果.所以 ...

  8. yk-随记

    $config = Loader::loadConfig('smarty');

  9. CF271D 【Good Substrings】

    定义哈希函数 \(H(c)=\sum_{i = 1} ^ m c_i*b^{m-i}\) \(H(C,K+1)=H(C,K)*b+C_{K+1}\)(K个坏字母) 用long long #includ ...

  10. 洛伦兹曲线(Lorenz curve)提升指数、提升表和提升图

    sklearn实战-乳腺癌细胞数据挖掘 https://study.163.com/course/introduction.htm?courseId=1005269003&utm_campai ...