状态寄存器包含了最近执行的算术指令的结果信息。这些信息可以用来改变程序流程以实现条件操作。如指令集所述,所有ALU 运算都将影响状态寄存器的内容。这样,在许多情况下就不需要专门的比较指令了,从而使系统运行更快速,代码效率更高。
在进入中断服务程序时状态寄存器不会自动保存,中断返回时也不会自动恢复。这些工作需要软件来处理。
AVR 中断寄存器 SREG 定义如下:
·Bit 7 – I: 全局中断使能
I 置位时使能全局中断。单独的中断使能由其他独立的控制寄存器控制。如果I 清零,则不
论单独中断标志置位与否,都不会产生中断。任意一个中断发生后I 清零,而执行RETI
指令后I 恢复置位以使能中断。I 也可以通过SEI 和CLI 指令来置位和清零。
·Bit 6 – T: 位拷贝存储
位拷贝指令BLD 和BST 利用T 作为目的或源地址。BST 把寄存器的某一位拷贝到T,而
BLD 把T 拷贝到寄存器的某一位。
·Bit 5 – H: 半进位标志
半进位标志H 表示算术操作发生了半进位。此标志对于BCD 运算非常有用。详见指令集
的说明。
·Bit 4 – S: 符号位, S = N ⊕ V
S 为负数标志N 与2 的补码溢出标志V 的异或。详见指令集的说明。
·Bit 3 – V: 2 的补码溢出标志
支持2 的补码运算。详见指令集的说明。
·Bit 2 – N: 负数标志
表明算术或逻辑操作结果为负。详见指令集的说明。
·Bit 1 – Z: 零标志
表明算术或逻辑操作结果为零。详见指令集的说明。
·Bit 0 – C: 进位标志
表明算术或逻辑操作发生了进位。详见指令集的说明。
上一篇:ATmega48 通用寄存器
下一篇:ATmega48 ALU
推荐阅读最新更新时间:2024-11-10 12:00
设计资源 培训 开发板 精华推荐
- 用于编程欠压锁定的 LT3066IDE-3.3 线性稳压器的典型应用电路
- X-NUCLEO-IHM02A1,基于用于 STM32 Nucleo 的 L6470 两轴步进电机驱动器的扩展板
- NB4N507ADEVB:PECL 时钟合成器评估板
- LTC1143L-ADJ 低压差双路 5V/2A、3.3V/1A 转换器的典型应用电路
- AM2G-0512SH30Z 12V 2瓦DC-DC转换器的典型应用
- 高频焊台 V1.0
- VNH7070BAS评估板
- 使用 Analog Devices 的 LTC2908IDDB-C1 的参考设计
- LT1615、具有负载断接功能的 20V 双输出转换器
- ADA4627-1ARZ-RL带保护同相放大器典型应用电路