ARM中SP、LR、PC三个寄存器介绍

寄存器定义和用途

定义

寄存器是中央处理器内的组成部份。寄存器是有限存贮容量的高速存贮部件,它们可用来暂存指令、数据和位址。

用途
  • 可将寄存器内的数据执行算术及逻辑运算;
  • 存于寄存器内的地址可用来指向内存的某个位置,即寻址;
  • 可以用来读写数据到电脑的周边设备。

ARM中特殊的三个寄存器

在ARM体系中,一般分为四种寄存器:通用目的寄存器堆栈指针(SP)连接寄存器(LR) 以及 程序计数器(PC), 其中需要着重理解后面三种寄存器。

堆栈指针R13(SP)
  • 每一种异常模式都有其自己独立的r13,它通常指向异常模式所专用的堆栈,也就是说五种异常模式、非异常模式(用户模式和系统模式),都有各自独立的堆栈,用不同的堆栈指针来索引。
  • 当ARM进入异常模式的时候,程序就可以把一般通用寄存器压入堆栈,返回时再出栈,保证了各种模式下程序的状态的完整性。
连接寄存器R14(LR)
  • 保存子程序返回地址。使用BL或BLX时,跳转指令自动把返回地址放入r14中;
  • 子程序通过把r14复制到PC来实现返回,通常用下列指令:MOV PC, LR;BX LR;
  • 当异常发生时,异常模式的R14用来保存异常返回地址,将R14如栈可以处理嵌套中断。
程序计数器R15(PC)
  • PC是有读写限制的;
  • 没有超过读取限制的时候,读取的值是指令的地址加上8个字节,由于ARM指令总是以字对齐的,故bit[1:0]总是00;
  • 在CM3内部使用了指令流水线,读PC时返回的值是当前指令的地址+4.
  • 向PC中写数据,就会引起一次程序的分支(但是不更新LR寄存器),CM3中的指令至少是半字对齐的,所以PC的LSB总是读回0。
  • 在分支时,无论是直接写 PC 的值还是使用分支指令,都必须保证加载到 PC 的数值是奇数(即 LSB=1),用以表明这是在Thumb 状态下执行。
  • 倘若写了 0,则视为企图转入 ARM 模式,CM3 将产生一个 fault 异常。
  • 15
    点赞
  • 74
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: ARM体系结构在数据类型级和寄存器堆栈操作方面有许多实验可以进行。数据类型级操作包括对不同数据类型的操作和操作数的大小端模式处理。寄存器堆栈操作主要涉及寄存器的读取、写入和压栈、出栈等操作。 在数据类型级操作实验,可以通过编写程序来演示不同数据类型的操作。例如,可以编写一个程序来实现整数和浮点数的相加、相乘等操作,并观察结果的正确性。还可以测试在不同大小端模式下的数据存储和读取方式,验证ARM的数据存储方式的灵活性和兼容性。 在寄存器堆栈操作实验,可以编写程序来实现寄存器的读取和写入操作。通过编写一段程序,可以将一个数值存储到某个寄存器,然后再将其读取出来并进行比较,以验证寄存器操作的正确性。此外,还可以编写程序来实现寄存器的堆栈操作,例如实现寄存器的压栈和出栈操作,并观察栈顶的值的变化情况,来验证堆栈操作的正确性和有效性。 总之,通过进行ARM体系结构数据类型级和寄存器堆栈操作的实验,可以加深对ARM体系结构的理解和掌握,同时也可以验证ARM的灵活性和可靠性。 ### 回答2: ARM体系结构的数据类型级与寄存器堆栈操作操作实验是一种用来研究ARM处理器的数据类型与寄存器堆栈的操作的实验。在这个实验,我们可以深入了解ARM处理器数据类型的特点以及寄存器堆栈的操作。 数据类型级是指ARM处理器所支持的数据类型的级别。ARM处理器支持多种数据类型,包括整数、浮点数、向量等。在实验,我们可以通过编写程序来实例化不同的数据类型,并对其进行操作和计算。例如,我们可以实现整数之间的加法、浮点数之间的乘法等运算,来观察ARM处理器对不同数据类型的处理能力和速度优势。 寄存器堆栈操作是指对寄存器和堆栈的读取、写入和操作。ARM处理器有多个寄存器,用于存储临时数据和指令执行过程的计算结果。堆栈用于存储函数调用的返回地址和局部变量等信息。在实验,我们可以编写程序,通过操作寄存器和堆栈来实现一些功能,如函数调用、递归等。 通过进行ARM体系结构的数据类型级与寄存器堆栈操作操作实验,我们可以更好地理解ARM处理器的内部结构和运行原理。这不仅有助于我们优化程序的执行效率和性能,还可以帮助我们更深入地理解ARM体系结构的特点和优势。实验可以通过软件仿真或硬件实现来进行,选择适合的实验器材和软件工具进行实验,能够更好地模拟和验证ARM处理器的性能和功能。 ### 回答3: ARM体系结构的数据类型级别包括字节(8位)、半字(16位)、字(32位)和双字(64位)。通过数据类型级别,ARM可以支持不同精度的数据处理,提高了数据处理的效率和灵活性。 在ARM体系结构寄存器是非常重要的组成部分。寄存器是一种位于处理器内部的高速存储器,用于临时存储数据和指令。ARM处理器具有多个通用寄存器,其有几个寄存器是专门用于存储特定的值和执行特定的操作的,如程序计数器(PC)、堆栈指针(SP)和链接寄存器LR)。 在ARM体系结构寄存器堆栈操作是指将寄存器的内容保存到堆栈,或者从堆栈恢复寄存器的内容。这样可以在需要时保存寄存器的值,以便在稍后的时间点进行恢复,以确保程序执行的正确性和连续性。 寄存器堆栈操作通常包括以下几个步骤: 1. 压栈:将要保存的寄存器的值按顺序依次压入堆栈。这样可以确保在程序执行后能够准确地恢复寄存器的值。 2. 弹栈:当需要恢复寄存器的值时,按照相反的顺序从堆栈取出寄存器的值,并将其存放回相应的寄存器。 通过寄存器堆栈操作,可以在程序执行过程暂时保存一些寄存器的值,以便在需要时进行恢复,保证程序的正确执行。同时,寄存器堆栈操作也可以用于嵌套子程序的调用和返回,确保程序的顺利执行和传递参数等。 总之,ARM体系结构的数据类型级别和寄存器堆栈操作是为了提高数据处理的效率和灵活性以及保证程序的正确性而设计的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值