ARM的37个寄存器

(一)概述

        ARM处理器含有37个寄存器,这些寄存器包含以下两类:

  • 31个通用寄存器:包括程序计数器PC等,都是32位长度的寄存器。
  • 6个状态寄存器
  • *37个寄存器中30个为“通用型”,1个固定用作PC,一个固定用作CPSR,5个固定用作5种异常模式下的SPSR。

如下图:

下图是 7种工作模式下每个模式下的寄存器列表: 

(二) CPSR程序状态寄存器

 主要记住高四位:

1. 条件标志位 

 -N: Negative result from ALU

 -Z: Zero result from ALU

 -C: ALU operation Carried out (进位/借位)

 -V: ALU operation overflowed (溢出)

* N=1时,说明运算的结果为负数,N=0时,说明运算的结果为正数或零。

* Z=1时,说明运算的结果为0,Z=0时,说明运算的结果为非0。

* C:

 - 加法运算(包括CMP):当运算结果产生了进位时(无符号数溢出),C=1,否则为0。

 - 减法运算(包括CMP):当运算结果产生了借位时(无符号数溢出),C=0,否则C=1。

 - 对于包含移位操作的非加减指令操作时,C为移除值的最后一位。

 - 对于其它的非加减指令,C的值通常不变。

* V:

 - 对于加减法运算指令,当操作数和运算结果为二进制的补码表示的带符号数时,V=1表示符号位溢出

 - 对于其它的非加减法指令,V的值通常不变。

2. Q位:

* 在ARM V5及以上的版本的E系列处理器中,Q标识位指示增强的DSP运算指令是否发生了溢出,在其它版本的处理器中,Q未定义。

3. J位:

* 仅ARM 5TE/J 架构支持

* J=1时,处理器处于Jazelle状态

4. 中断禁止位:

* I=1,禁止IRQ

* F=1,禁止FIQ

5. T位:

* 仅ARM xT架构支持

* T=0,处理器处于ARM状态

* T=1,处理器处于Thumb状态

6. Mode位:

* 处理器工作模式选择位

注意:

* CPSR中的各个位表明了CPU的某个状态信息,这些信息和后面我们用的汇编指令息息相关。

* CPSR的I、F位和开中断、关中断有关。

* CPSR的Mode位决定了CPU的工作模式,在uBoot代码中会使用汇编代码进行设置。

PC(R15)程序控制寄存器:

* PC(Program Control Register)为程序指针,PC指向哪里,CPU就会指向哪条指令(所以程序跳转时就是把目标地址代码放到PC中)。

* 整个CPU中只有一个PC(CPSR也只有一个,但SPSR有5个)。

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值