arm 寄存器

本文详细介绍了ARM处理器中的寄存器系统,包括16个32位通用寄存器的功能划分及其在不同处理器模式下的行为。特别关注了程序计数器PC、链接寄存器LR以及状态寄存器CPSR的作用,并解释了如何利用这些寄存器进行高效的子程序调用和异常处理。

ARM1632位的寄存器(r0r15)。

 r15充当程序寄存器PCr14link register)存储子程序的返回地址,r13存储的是堆栈地址。

ARM有一个当前程序状态寄存器:CPSR

一些寄存器(r13r14)在异常发生时会产生新的instances,比如IRQ处理器模式,这时处理器使用r13_irqr14_irq

 ARM的子程序调用是很快的,因为子程序的返回地址不需要存放在堆栈中。

1 ARM处理器共有37个寄存器,其中包括:

i. 31个通用寄存器,包括程序计数器(PC)在内。都是32位寄存器

ii. 6个状态寄存器,都是32位寄存器,但目前只使用了其中12

 

2 ARM处理器有7种不同的处理器模式,在每一种处理器模式中有一组相应的寄存器组。任意时刻(也就是任意的处理器模式下),可见的寄存器包括15个通用寄存器(R0R14)、一个或两个状态寄存器及程序计数器(PC)。在所有的寄存器中,有些是各模式共用的同一个物理寄存器,有些是各模式自己拥有的独立的物理寄存器。

 

3 通用寄存器可以分为3类:未备份寄存器(R0R7)、备份寄存器(R8~R14)和程序计数器PCR15)。对于每一个未备份寄存器来说,在所有的处理器模式下指的都是同一个物理寄存器。对应备份寄存器R8R12来说,每个寄存器对应两个不同的物理寄存器,这使得中断处理非常简单。例如,仅仅使用R8~R14寄存器时,FIQ处理程序可以不必执行保存和恢复中断现场的指令,从而使中断处理过程非常迅速。对于备份寄存器R13R14来说,每个寄存器对应6个不同的物理寄存器,其中的一个是用户模式和系统模式共用的,另外的5个对应于其他5种处理器模式。

 

4 每一种异常模式拥有自己的物理的R13。应用程序初始化该R13,使其指向该异常模式专用的栈地址。当进入异常模式时,可以将需要使用的寄存器保存在R13所指的栈中;当退出异常处理程序时,将保存在R13所指的栈中的寄存器值弹出。这样就使异常处理程序不会破坏被其中断程序的运行现场。

 

5 寄存器R14又被称为连接寄存器(Link RegisterLR),在ARM体系中具有下面两种殊的作用:

 

i. 每一种处理器模式自己的物理R14中存放当前子程序的返回地址。当通过BLBLX指令调用子程序时,R14被设置成该子程序的返回地址。在子程序中,当把R14的值复制到程序计数器PC中时,子程序即返回。

 

ii. 当异常中断发生时,该异常模式特定的物理R14被设置成该异常模式将要返回的地址,对于有些异常模式,R14的值可能与将返回的地址有一个常数的偏移量。具体的返回方式与子程序返回方式基本相同。

 

### ARM架构中的寄存器及其作用 ARM架构中的寄存器是处理器的核心组件之一,主要用于存储临时数据、指令地址以及控制信息等[^1]。这些寄存器可以分为多个类别,每种类型的寄存器都有特定的功能。 #### 通用寄存器 ARM架构中有多个通用寄存器(General Purpose Registers),通常编号为 R0 到 R15。其中部分寄存器具有特殊用途: - **R0-R12**: 这些寄存器可以用作任意目的的数据存储位置。它们不保留任何特殊的含义,在程序执行过程中可自由使用。 - **R13 (SP)**: 被定义为堆栈指针(Stack Pointer),用于指向当前线程的堆栈顶部。它在函数调用和局部变量管理中起着重要作用。 - **R14 (LR)**: 链接寄存器(Link Register),当发生子程序调用时自动保存返回地址。这意味着每当BL或BLX指令被执行时,下一条指令的地址会被写入到这个寄存器里以便稍后能够跳回原处继续运行代码片段。 - **R15 (PC)**: 程序计数器(Program Counter),始终指向即将执行的下一条指令的位置。值得注意的是,在某些模式切换情况下也可能改变其值从而实现异常处理等功能。 除了上述提到的主要几类之外还有状态标志位等相关概念也非常重要但这里不做详述因为篇幅原因仅列举几个典型例子说明即可满足初学者需求。 下面给出一段简单的汇编语言示例展示如何利用这些基本寄存器完成加法运算任务: ```assembly MOV R0, #5 @ 将立即数5加载至R0 ADD R1, R0, #7 @ 把R0里的数值加上另一个立即数7并将结果放入R1 SUB R2, R1, #3 @ 减去常量3得到最终答案并储存在R2之中 ``` 通过以上实例可以看出合理运用各类不同功能定位清晰明了而又相互配合默契良好的寄存器资源确实可以帮助开发者更高效便捷地构建复杂逻辑流程体系结构模型等等诸多方面均有所体现出来。 另外值得一提的内容涉及到实际项目开发当中如果想要进一步深入理解掌握底层硬件运作机制的话那么直接操控具体外设单元比如GPIO端口之类的往往就需要借助于相应配置型专用性质较强的所谓“外围设备控制器”类型寄存器来进行设置了比如说要驱动点亮一颗LED小灯泡就必须先搞清楚目标单片机芯片内部关于该管脚关联属性参数设置方法步骤顺序等方面的知识点才行[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值