特殊的寄存器

本文详细介绍了ARM处理器中的关键寄存器,包括栈指针寄存器SP、链接寄存器LR、程序计数器PC、当前程序状态寄存器CPSR及其备份SPSR。CPSR中包含了如负数标志N、零标志Z、进位标志C、符号位变化标志V等信息,以及中断屏蔽位和模式位,用于控制处理器的工作状态和中断处理。此外,还提到了ARM和Thumb指令集的区别。
摘要由CSDN通过智能技术生成

1> R13 --别名--> SP : The Stack Pointer(栈指针寄存器)

SP中存放的是栈的地址

2> R14 --别名--> LR : The Linking Register (链接寄存器)

LR中存放的是程序的返回地址

3> R15 --别名--> PC :The Program Counter (程序计数寄存器)

PC中存放的是当前取指指令的地址

4> CPSR : Current Program Stated Register 当前程序状态寄存器

存放的是当前程序的运行的状态。 比如:工作模式。

5> SPSR : Saved Program Stated Register 保存程序状态寄存器

用于对CPSR进行备份的

6> CPSR寄存器详解

N[31] : 指令的运算结果为负数,N位被自动置1,否则清0.

Z[30] : 指令的运算结果为零,Z位被自动置1,否则清0.

C[29] :

加法:产生进位,C位被自动置1,否则清0.

减法:产生借位,C位被自动清0,否则置1.

进位/借位:低32位向高32位进位或者借位。

两个64位数相加,需要拆分成两个32位数进行加法运算,

先算低32位,再算高32位,在进行高32位运算时需要考虑低32位是否有进位。

V[28] : 符号位发生变化,V位被自动置1,否则清0.

I[7] : IRQ屏蔽位

I = 0 不屏蔽IRQ中断

I = 1 屏蔽IRQ中断

F[6] : FIQ屏蔽位

F = 0 不屏蔽FIQ中断

F = 1 屏蔽FIQ中断

T[5] : 状态位T = 0 : ARM状态 --》执行ARM指令集

T = 1 : Thumb状态 ---》执行Thumb指令集

ARM指令集和Thumb指令集区别

ARM指令集:

每条指令占4个字节的空间

Thumb指令集:

每条指令占2个字节的空间

ARM指令集的功能性比Thumb指令集的功能更加完善。

Thumb指令集的指令的密度要比ARM指令集高。

M[4:0] : 模式位

10000 User mode;

10001 FIQ mode;

10011 SVC mode;

10111 Abort mode;

11011 Undfined mode;

11111 System mode;

10110 Monitor mode;

10010 IRQ

其他的保留

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小徐的记事本

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值