【汇编语言】标志寄存器PSW

简介

8086CPU设置了一个16位标志寄存器PSW(也叫FR)

其中规定了9个标志位,用来存放运算结果特征和控制CPU操作。

在这里插入图片描述

  • 反映指令对数据作用之后,结果的状态(不是结果本身)。这些状态将控制后续指令的执行;
  • 有些运算操作将影响全部状态标志,如加法、减法运算;
  • 有些操作影响部分状态标志,如移位操作;
  • 有些指令的操作不影响任何状态标志,如数据传送指令。

9个标志位可以分为两类:

  • 状态标志
    CF,PF,AF,ZF,SF,OF
  • 控制标志
    IF,DF,TF

在这里插入图片描述

状态标志

  1. CF(Carry Flag)— 进位标志位
    CF = 1:本次运算中最高位(D15 或 D7)有进位(加法运算)或有借位(减法运算)

  2. PF(Parity Flag)— 奇偶校验标志位
    PF=1:本次运算中有偶数个“1”;
    PF=0:表示本次运算结果中有奇数个“1”

  3. AF(Auxiliary Carry Flag)— 辅助进位标志位
    AF=1:运算结果的8位数据中,低4位向高4位有进位或有错位。
    该标志只在十进制数运算中有用。

  4. ZF(Zero Flag)— 零标志位
    ZF=1:本次运算结果位零;
    ZF=0:本次运算结果非零。

  5. SF(Sign Flag)— 符号标志位
    SF=1:本次运算结果的最高位(D15或D7)为“1”
    否则SF=0;

  6. OF(Overflow Flag)— 溢出标志位
    OF=1:本次运算结果产生溢出;
    OF=0:本次运算结果没产生溢出。


控制标志

  1. 方向标志DF(Direction Flag):
    DF=1 ,串操作时地址自动减量;
    DF=0,串操作时地址自动增量。

  2. 中断允许标志IF(Interrupt Enable Flag):
    IF=1,允许CPU接收外部中断 请求,
    IF=0,屏蔽外部中断请求。

  3. 追踪标志TF(Trace Flag):
    TF=1,使处理进入单步方式,以便于调试。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值