深入理解SP、LR和PC
来源:互联网 发布:淘宝闲鱼小二介入草率 编辑:程序博客网 时间:2024/06/06 15:48
深入理解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,否则后果不可预测。
- 深入理解SP、LR和PC
- 深入理解SP、LR和PC
- 深入理解SP、LR和PC
- 深入理解SP、LR和PC
- 深入理解SP、LR和PC
- 深入理解SP、LR和PC
- 深入理解SP、LR和PC
- 深入理解SP、LR和PC
- 深入理解SP、LR和PC
- 深入理解SP、LR和PC
- 深入理解SP、LR和PC
- 理解SP、LR和PC
- 深入理解ARM的SP LR PC这三个寄存器
- lr pc sp寄存器相关理解
- LR PC SP寄存器
- sp lr pc详解
- SP,LR,PC寄存器
- ARM 内核SP,LR,PC寄存器
- OS_CPU.h,OS_CPU_A.s,OS_CPU.c
- UCOS移植代码之LAMMY分析--OS_CPU_C.C
- UCOS移植代码之LAMMY分析--OS_CPU_C.C
- Kotlin系统化学习系列文章(所有文章的链接)
- Maven配置Tomcat服务器
- 深入理解SP、LR和PC
- uCOS在51单片机上的移植心得
- python3删除sina微博
- java中的逻辑运算符和位运算符
- OSTaskStkInit():任务堆栈结构的初始化
- C++二叉树递归遍历
- HDU 1847 Good Luck in CET-4 Everybody!
- UC/OS-II的详细移植笔记 两种处理器的移植比较(S1C33209&&S3C44BOX)
- 计算机时间:1970年1月1日