状态寄存器中的各个状态标志位是依据“alu上一次的运算结果”来设置标志位的;状态寄存器又名条件码寄存器,是计算机核心部件运算器的一部分,主要用来存放体现当前指令执行结果的各种状态信息和控制信息。
本教程操作环境:windows10系统、dell g3电脑。
状态寄存器中的各个状态标志位是依据什么来设置标志位的状态寄存器中的各个状态标志位是依据“alu上一次的运算结果”来设置标志位的
状态寄存器又名条件码寄存器,它是计算机系统的核心部件——运算器的一部分,状态寄存器用来存放两类信息:
一类是体现当前指令执行结果的各种状态信息(条件码),如有无进位(cf位)、有无溢出(ov位)、结果正负(sf位)、结果是否为零(zf位)、奇偶标志位(p位)等;
另一类是存放控制信息(psw:程序状态字寄存器),如允许中断(if位)、跟踪标志(tf位)等。有些机器中将psw称为标志寄存器fr(flag register)
在arm中有6个状态寄存器,arm7tdmi内核包含1个cpsr和5个供异常处理程序使用的spsr。cpsr反映了当前处理器的状态,其包含:
4个条件代码标志(负(n)、零(z)、进位(c)和溢出(v) );
2个中断禁止位,分别控制一种类型的中断;
5个对当前处理器模式进行编码的位;
1个用于指示当前执行指令(arm还是thumb)的位。
psw各标志位解释:
1. cy(carry): 用于表示加法运算中的进位和减法运算中的借位,加法运算中有进位或减法运算中有借位则cy位置为1,否则为0
2. ac(auxiliary carry): 与cy基本相同,不同的是低4位与高4位间的运算。
3.f0(flag zero用户标志位): 该位是用户根据自己的需要而自己设定的标志位,用户可以通过设置该位来决定程序的流向和分支。
4. rs1,rs0: 8051有8个8位工作寄存器r0~r7,它在ram中的实际物理地理可以根据需要来选择确定。
00:00h~07h
01:08h~0fh
10:10h~17h
11:18h~1fh
5.ov: 表示运算过程中是否发生了溢出,若结果超过了8位二进制数所能表示数据的范围即有符号数-128~+127,则标志位置1。
6.op: 奇偶标志位用来指示运算结果中1的个数的奇偶性,若p=0,则累加器a中1的个数为偶数;若p=1,则累加器a中1的个数为奇数。
更多相关知识,请访问常见问题栏目!
以上就是状态寄存器中的各个状态标志位是依据什么来设置标志位的的详细内容。