寄存器

作者: blank_white | 来源:发表于2020-06-21 15:39 被阅读0次

     一、标志寄存器PSW

    15  14  13  12  11  10  9   8   7   6   5   4   3   2   1   0
                    OF  DF  IF  TF  SF  ZF      AF      PF      CF
    

    标志寄存器PSW(程序状态字寄存器PSW)
    标志寄存器PSW是一个16为的寄存器。它反映了CPU运算的状态特征并且存放某些控制标志。8086使用了16位中的9位,包括6个状态标志位和3个控制标志位。

    CF(进位标志位):当执行一个加法(减法)运算时,最高位产生进位(或借位)时,CF为1,否则为0。
    ZF零标志位:若当前的运算结果为零,则ZF为1,否则为0。
    SF符号标志位:该标志位与运算结果的最高位相同。即运算结果为负,则SF为1,否则为0。
    OF溢出标志位:若运算结果超出机器能够表示的范围称为溢出,此时OF为1,否则为0。判断是否溢出的方法是:进行二进制运算时,最高位的进位值与次高位的进位值进行异或运算,若运算结果为1则表示溢出OF=1,否则OF=0
    PF奇偶标志:当运算结果的最低16位中含1的个数为偶数则PF=1否则PF=0
    AF辅助进位标志:一个加法(减法)运算结果的低4位向高4位有进位(或借位)时则AF=1否则AF=0

    另外还有三个控制标志位用来控制CPU的操作,可以由程序进行置位和复位。
    TF跟踪标志:该标志位为方面程序调试而设置。若TF=1,8086/8088CPU处于单步工作方式,即在每条指令执行结束后,产生中断。
    IF中断标志位:该标志位用来控制CPU是否响应可屏蔽中断。若IF=1则允许中断,否则禁止中断。
    DF方向标志:该标志位用来控制串处理指令的处理方向。若DF=1则串处理过程中地址自动递减,否则自动递增。

    OD里能查看到 除IF标志外的 8个标志位

    image.png

     二、通用寄存器

    1.EBP栈底指针
    EBP是一个特殊的寄存器,通过EBP+偏移量 可以访问CALL里边的局部变量。它的低16位叫BP。//EAX和AX的关系
    2.ESP栈顶指针
    ESP栈顶指针与EBP构成的一段空间大小,一般就是本CALL局部变量的空间大小总和。ESP指针配合EBP使用。//SP

    栈顶是低地址单元, 栈底是高地址单元。

    相关文章

      网友评论

          本文标题:寄存器

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