lr pc sp寄存器相关理解

转载链接:http://hi.baidu.com/a843538946/item/4e2a34fe48b6e5be31c199ec
                http://blog.sina.com.cn/s/blog_62714d6a0100mjgx.html
                http://blog.chinaunix.net/uid-12461657-id-3068269.html
                http://blog.youkuaiyun.com/zhou1232006/article/details/6149548

                    (一)
看下面这个ARM汇编吧

BL  NEXT                                 ;跳转到子程序

.........                                          ;NEXT处执行

NEXT

..........

MOV  PC,LR                            ;从子程序返回

这里的BL是跳转的意思,LR(R14)保存了返回地址

PC(R15)是当前地址,把LR给PC就是从子程序返回

这里有一下总结

首先

1.SP(R13) LR(R14)PC(R15)

2.lr(r14)的作用问题,这个lr一般来说有两个作用:
1》.当使用bl或者blx跳转到子过程的时候,r14保存了返回地址,可以在调用过程结尾恢复。
2》.异常中断发生时,这个异常模式特定的物理R14被设置成该异常模式将要返回的地址。

另外注意pc,在调试的时候显示的是当前指令地址,而用mov lr,pc的时候lr保存的是此指令向后数两条指令的地址,大家可以试一下用mov pc,pc,结果得到的是跳转两条指令,这个原因是由于arm的流水线造成的,预取两条指令的结果.

3.》我以前看书不懂的地方

子程序返回的三种方法

现在总结如下

1.MOV PC,LR

2.BL LR

3.在子程序入口处使用以下指令将R14存入堆栈

STMFD    SP!,{<Regs>,LR}

对应的,使用以下指令可以完成子程序的返回

LDMFD  SP!,      {<Regs>,LR}

#Arm

                    
(二)

 异常的发生会导致程序正常运行的被打断,并将控制流转移到相应的异常处理(异常响应),有些异常(fiq、irq)事件处理后,系统还希望能回到当初异常发生时被打断的源程序
断点处继续完成源程序的执行(异常返回),这就需要一种解决方案,用于记录源程序的断
点位置,以便正确的异常返回。 
    类似的还有子程序的调用和返回。在主程序中(通过子程序调用指令)调用子程序时,
也需要记录下主程序中的调用点位置,以便将来的子程序的返回。

 

    在ARM处理器中使用 R14实现对断点和调用点的记录,即使用R14用作返回连接寄存器(LR )。在硬件上和指令执行上,CPU 自动完成相应返回点的记录。在ARM 汇编语言程序设计时,R14和LR通用。
    ARM处理器相应异常时,会自动完成将当前的PC保存到LR寄存器。
    ARM处理器执行子程序调用指令(BL )时,会自动完成将当前的PC的值减去4的结果数据保存到LR寄存器。即将调用指令的下紧邻指令的地址保存到LR。
    ARM处理器针对不同的模式,共有6个链接寄存器资源(LR ),其中用户模式和系统
模式共用一个 LR,每种异常模式都有各自专用的R14 寄存器(LR )。这些链接寄存器分别
为 R14、R14_svc、R14_abt、R14_und、R14_irq、R14_fiq,

   程序设计者要清晰处理器的模式与相应寄存器的对应关系,都是使用 R14,但不同模式下的R14 不是同一个物理资源,其内容可能天壤之别。
    R14 不用做链接寄存器(LR )时,也可以用做通用数据寄存器。

(三)

ARM处理器使用流水线来增加处理器指令流的速度,这样可使几个操作同时进行,并使处理与存储器系统之间的操作更加流畅,连续,能提供0.9MIPS/MHZ的指令执行速度。

    PC 代表程序计数器,流水线使用三个阶段,因此指令分为三个阶段执行:1.取指(从存储器装载一条指令);2.译码(识别将要被执行的指令);3.执行(处理 指令并将结果写回寄存器)。而R15(PC)总是指向“正在取指”的指令,而不是指向“正在执行”的指令或正在“译码”的指令。一般来说,人们习惯性约定 将“正在执行的指令作为参考点”,称之为当前第一条指令,因此PC总是指向第三条指令。当ARM状态时,每条指令为4字节长,所以PC始终指向该指令地址 加8字节的地址,即:PC值=当前程序执行位置+8;

    ARM指令是三级流水线,取指,译指,执行时同时执行的,现在PC指向的是正在取指的地址,那么cpu正在译指的指令地址是PC-4(假设在ARM状态 下,一个指令占4个字节),cpu正在执行的指令地址是PC-8,也就是说PC所指向的地址和现在所执行的指令地址相差8。
    当突然发生中断的时候,保存的是PC的地址
    这样你就知道了,如果返回的时候返回PC,那么中间就有一个指令没有执行,所以用SUB pc lr-irq #4


(四)

深入理解ARM的这三个寄存器,对编程以及操作系统的移植都有很大的裨益。

1、堆栈指针r13(SP):每一种异常模式都有其自己独立的r13,它通常指向异常模式所专用的堆栈,也就是说五种异常模式、非异常模式(用户模式和系统模式),都有各自独立的堆栈,用不同的堆栈指针来索引。这样当ARM进入异常模式的时候,程序就可以把一般通用寄存器压入堆栈,返回时再出栈,保证了各种模式下程序的状态的完整性。

2、连接寄存器r14(LR):每种模式下r14都有自身版组,它有两个特殊功能。

    (1)保存子程序返回地址。使用BL或BLX时,跳转指令自动把返回地址放入r14中;子程序通过把r14复制到PC来实现返回,通常用下列指令之一:
                        MOV PC, LR 
                        BX LR

    通常子程序这样写,保证了子程序中还可以调用子程序。
                         stmfd sp!, {lr}
                         ……
                         ldmfd sp!, {pc}

    (2)当异常发生时,异常模式的r14用来保存异常返回地址,将r14如栈可以处理嵌套中断。

3、程序计数器r15(PC):PC是有读写限制的。当没有超过读取限制的时候,读取的值是指令的地址加上8个字节,由于ARM指令总是以字对齐的,故bit[1:0]总是00。当用str或stm存储PC的时候,偏移量有可能是8或12等其它值。在V3及以下版本中,写入bit[1:0]的值将被忽略,而在V4及以上版本写入r15的bit[1:0]必须为00,否则后果不可预测。

<think>嗯,用户问的是“pc lr sp”,这三个缩写可能在不同的领域有不同的含义,我需要先确定用户指的是什么。根据常见的缩写,首先想到的可能是在计算机科学或电子工程领域中的术语。 首先,“PC”通常指“程序计数器”(Program Counter),这是CPU中的一个寄存器,用来存储下一条要执行的指令的地址。程序计数器在指令执行过程中会自动递增,或者在跳转指令时被修改。这个解释比较常见,应该没错。 接下来是“LR”。在ARM架构中,LR代表“链接寄存器”(Link Register),用于存储子程序调用后的返回地址。当执行BL(分支并链接)指令时,LR会被设置为当前指令的下一条地址,这样在子程序执行完后可以返回到正确的位置。这个知识点可能需要确认,但ARM架构中的LR确实是这样的作用。 然后是“SP”,通常指“堆栈指针”(Stack Pointer),用于跟踪当前堆栈的顶部地址。堆栈用于存储临时数据、返回地址和局部变量等。堆栈指针在函数调用和中断处理中非常重要,确保数据的正确压入和弹出。这也是比较基础的概念,应该正确。 不过,用户可能是在特定的上下文中使用这些缩写,比如嵌入式系统、汇编语言编程或者计算机体系结构课程中的内容。需要确认这些缩写是否还有其他可能的解释,但根据常见的计算机术语,这三个缩写的解释应该是正确的。 需要检查是否有其他可能性,比如在某些特定领域或框架中的不同含义。例如,SP有时可能代表“服务提供商”(Service Provider)或“结构化编程”(Structured Programming),但在计算机体系结构或低级编程中,SP通常是堆栈指针。同样,PC也可能指“个人计算机”(Personal Computer),但结合LR(链接寄存器)来看,这里的上下文更可能是计算机体系结构或嵌入式系统。 总结下来,用户的提问应该是在询问计算机体系结构中的寄存器,因此将PC解释为程序计数器,LR为链接寄存器SP为堆栈指针是合理的。需要确保这些解释准确,并且用中文清晰表达,同时注意使用正确的LaTeX格式,如行内公式用$...$,独立公式用$$...$$,但在这个问题中可能不需要数学公式,所以重点放在术语解释上。 另外,要确保回答结构清晰,分点解释每个术语,帮助用户逐步理解。可能需要补充它们之间的关系,比如在函数调用时,PCLRSP如何协同工作,保存返回地址和管理堆栈。这样用户能更好地理解它们的作用和重要性。 需要验证每个术语的定义是否准确,比如程序计数器是否确实存储下一条指令地址,链接寄存器在ARM中的用途,以及堆栈指针的作用。这些知识点在计算机组成原理中都是基础内容,应该没问题。如果有不确定的地方,可能需要查阅资料确认,但根据已有的知识,这些解释是正确的。 最后,确保回答符合用户的要求,使用中文,结构清晰,分点说明,并且正确使用LaTeX格式(如果有数学表达式的话)。在这个问题中,可能不需要数学公式,所以主要按照用户的要求组织内容即可。</think>以下是关于 **PC**、**LR** 和 **SP** 的逐步解释: --- ### 1. **PC (Program Counter,程序计数器)** - **定义**: PC 是 CPU 中的一个专用寄存器,用于存储**下一条要执行的指令的内存地址**。 - **作用**: - 在顺序执行指令时,PC 会自动递增,指向下一条指令。 - 遇到分支或跳转指令(如 `jmp`、`call`)时,PC 会被直接修改为目标地址。 - **重要性**: PC 是程序执行流程的核心控制单元,确保指令按正确顺序执行。 --- ### 2. **LR (Link Register,链接寄存器)** - **定义**: LR 是某些处理器架构(如 ARM)中的专用寄存器,用于**保存子程序调用后的返回地址**。 - **作用**: - 当执行子程序调用指令(如 ARM 的 `BL` 指令)时,LR 会被自动设置为当前指令的下一条地址。 - 子程序执行完毕后,可通过将 LR 的值加载到 PC 中,返回到调用前的代码位置。 - **示例**: 在 ARM 中: ```assembly BL subroutine ; 调用子程序,LR = 下一条指令地址 ... ; 返回后继续执行此处 subroutine: ; 子程序 ... BX LR ; 返回到 LR 指定的地址 ``` --- ### 3. **SP (Stack Pointer,堆栈指针)** - **定义**: SP 是 CPU 中的寄存器,指向当前**堆栈的顶部地址**。 - **作用**: - 堆栈用于存储临时数据、函数调用的返回地址、局部变量等。 - 当数据压栈(`push`)时,SP 递减;弹栈(`pop`)时,SP 递增(具体方向取决于架构)。 - **重要性**: SP 管理函数调用和中断处理时的上下文保存与恢复,是内存动态分配的关键。 --- ### 三者的协同工作 在函数调用过程中,PCLRSP 共同作用: 1. 调用函数时: - PC 指向调用指令的地址。 - LR 保存返回地址(PC 的下一条指令)。 - SP 调整堆栈空间,保存寄存器和局部变量。 2. 函数返回时: - LR 的值被加载到 PC,恢复执行流程。 - SP 恢复调用前的堆栈位置。 --- ### 总结 | 缩写 | 全称 | 核心作用 | |------|----------------|---------------------------------| | PC | 程序计数器 | 控制指令执行顺序 | | LR | 链接寄存器 | 保存函数返回地址(ARM 等架构) | | SP | 堆栈指针 | 管理堆栈内存的动态分配 | 这些寄存器在底层程序执行和系统级开发中至关重要。如果需要进一步了解具体架构(如 x86、ARM)中的差异,可以进一步探讨!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值