美文网首页
(四)标记寄存器

(四)标记寄存器

作者: SwiftAlan | 来源:发表于2017-07-23 19:33 被阅读0次

8086 CPU 的标记寄存器有 16 位,其中存储的信息通常被称为程序状态字(PSW),标记寄存器和其他寄存器不一样,其他寄存器是用来存放数据的,都是整个寄存器具有一个含义,而标记寄存器是按位起作用的,它的每一位都有专门的含义记录特定的信息,有些指令的执行是影响标记寄存器的,比如 add sub mul div inc or and 等,它们大都是运算指令,在使用一条指令的时候,要注意执行结果对标记寄存器的那些标志位造成影响。
标记寄存器的结构如下:

1、CF 进位标记位

标记寄存器的第 0 位是 CF 进位标记位。一般情况下,在进行无符号数运算的时候,它记录了运算结果的最高有效位向更高位的进位值,或从更高位的借位值。

2、PF 奇偶标记位

标记寄存器的第 2 位是 PF 奇偶标记位,它记录相关指令执行后,其结果的所有 bit 位中 1 的个数是否为偶数,如果 1 的个数为偶数,PF = 1,如果 1 的个数为奇数,PF = 0

3、ZF 零标记位

标记寄存器的第 6 位是 ZF 零标记位,它记录相关指令执行后,其结果是否为 0,如果为 0ZF = 1,如果不为 0ZF = 0

4、SF 符号标记位

标记寄存器的第 7 位是 SF 符号标记位,它记录相关指令执行后,其结果是否为负数,如果为负数,SF = 1,如果非负,SF = 0

5、DF 方向标志位

标记寄存器的 10 位是 DF ,在串处理指令中,控制每次操作后 si di 的增减。

df = 0 每次操作后 si、di 递增
df = 1 每次操作后 si、di 递减
看一下下面的串传送指令
指令:movsb
功能:执行 movsb 指令相当于进行下面几个步骤
(1)((es) 16 + (di))= ((ds) 16 + (si))
(2)如果 df = 0 则:(si)= (si)+ 1
(di)= (di)+ 1

(2)如果 df = 0 则:(si)= (si)- 1
(di)= (di)- 1

由于 df 位决定着串传送指令执行后 sidi 改变的方向,所以 CPU 提供下面两条指令对 df 位进行设置

cld 指令:将标志寄存器的 df 位置 0
stb 指令:将标志寄存器的 df 位置 1

6、OF 溢出标记位

标记寄存器的第 11 位是 OF 溢出标记位,一般情况下,它记录了有符号数运算的结果是否发生了溢出,如果发生溢出,OF = 1,如果没有,OF = 0

7、ADC 指令

adc 是带进位加法指令,它利用了 CF 位上记录的进位值

指令格式:adc 操作对象1,操作对象2
功能:操作对象1 = 操作对象1 + 操作对象2 + CF

8、SBB 指令

sbb 是带借位减法指令,它利用了 CF 位上记录的借位值

指令格式:sbb 操作对象1,操作对象2
功能:操作对象1 = 操作对象1 - 操作对象2 - CF

9、CMP 指令

cmp 是比较指令,cmp 相当于减法指令,只是不保存结果,cmp 指令执行后将对标记寄存器产生影响,其他相关指令通过识别这些被影响的标志寄存器位来得知比较结果。

指令格式:cmp 操作对象1,操作对象2
功能:操作对象1 - 操作对象2,但不保存结果,仅仅根据计算结果对标记寄存器进行设置

10、检测比较结果的条件转移指令

常用的根据无符号的比较结果进行转移的条件转移指令
指令 含义 检测的相关标志位
je 等于则跳转 zf = 1
jne 不等于则跳转 zf = 0
jb 低于则跳转 cf = 1
jnb 不低于则跳转 cf = 0
ja 高于则跳转 cf = 0 且 zf = 0
jna 不高于则跳转 cf = 1 且 zf = 1
这些指令比较常用,他们都比较好记忆,第一个字母都是 j ,表示 jump ,后面的字母表示如下含义
含义
e 表示 equel
ne 表示 not equel
b 表示 below
nb 表示 not below
a 表示 above
na 表示 not above

11、pushf 和 popf 指令

pushf 的功能是将标志寄存器的值压栈,而 popf 是从栈中弹出数据,送入标记寄存器中,pushfpopf 为直接访问标志寄存器提供了一直方法。

相关文章

  • (四)标记寄存器

    8086 CPU 的标记寄存器有 16 位,其中存储的信息通常被称为程序状态字(PSW),标记寄存器和其他寄存器不...

  • 3.Proteus仿真实例

    【投稿】:3.3四位移位寄存器 【作者】:0106_刘杰;0121_丁爽 3.3四位移位寄存器 左移寄存器: 3....

  • 8086/8088寄存器

     8086/8088 包括四个16位数据寄存器,两个16位指针寄存器,两个16位变址寄存器,一个16位指令指针,四...

  • 三.寄存器

    我们要学习的就是寄存器 AX,BX,CX,DX这四个寄存器通常存放一般性数据,俗称寄存器,在8086中叫做这个名字...

  • [031][汇编语言]寻址 ax bx cx dx sp bp

    reg寄存器 与 sreg段寄存器 reg 寄存器 sreg 段寄存器 可用做寻址[...] bp寄存器 默认使用...

  • 四.段寄存器

    CPU访问内存单元的时候,要给出内存单元的地址,所有的内存单元都有唯一的地址,我们也称为物理地址 但是,但是!!!...

  • Modbus功能码

    1 简述 Modbus寄存器分为四种,如表1.1所示: 表1.1 寄存器分类 2 常用功能码 Modbus中常用的...

  • stm32 TIM(通用定时器)

    寄存器描述CR1控制寄存器1CR2控制寄存器2SMCR从模式控制寄存器DIERDMA/中断使能寄存器SR状态寄存器...

  • 【HTML】 四、图像标记

    HTML标记语言 一、HTML的语法二、html的基本结构三、文档设置标记四、图像标记五、超链接的使用六、表格七、...

  • 汇编的几个指令

    常见寄存器 寄存器x86x86-64armarm64累加寄存器EAXRAX基址寄存器EBXRBX计数寄存器ECXR...

网友评论

      本文标题:(四)标记寄存器

      本文链接:https://www.haomeiwen.com/subject/cgimkxtx.html