寄存器

作者: flamez57 | 来源:发表于2021-09-28 11:44 被阅读0次

    一、普通寄存器 AX、BX、CX、DX (8086CPU 16位)

    一个寄存器  16位 == 两个字节 == 一个字 == (0000H~FFFFH)

    任何两个地址连续的内存单元,N号单元和 N+1号单元,可以将它们看成两个内存单元 ,也可以看成一个地址为N的字单元中的高位字节单元和低位字节单元。

    拿AX举例   AX 高位 AH(一个字节)  低位AL(一个字节)  可以这样分开使用

    二、段得来源意义

    CPU访问内存单元时,必须向内存提供内存单元的物理地址。

    8086CPU在内部用段地址和偏移地址移位相加的方法形成最终的物理地址。

    CPU可以用不同的段地址和偏移地址形成同一个物理地址。

    8086CPU用“(段地址×16)+偏移地址=物理地址”的方式给出内存单元的物理地址,使得我们可以用分段的方式来管理内存。

    三、段寄存器就是提供段地址的

    8086CPU有4个段寄存器:CS、DS、SS、ES

    CS:IP

    CS和IP是8086CPU中最关键的寄存器,它们指示了CPU当前要读取指令的地址。

    CS为代码段寄存器;

    IP为指令指针寄存器。

    对于代码段,将它的段地址放在 CS中,将段中第一条指令的偏移地址放在IP中,这样CPU就将执行我们定义的代码段中的指令;

    同时修改CS、IP的内容:

    jmp 段地址:偏移地址

    jmp 2AE3:3

    jmp 3:0B16

    功能:用指令中给出的段地址修改CS,偏移地址修改IP。

    仅修改IP的内容:

    jmp 某一合法寄存器

    jmp ax  (类似于 mov IP,ax)

    jmp bx

    功能:用寄存器中的值修改IP。

    DS和[address]

    CPU要读取一个内存单元的时候,必须先给出这个内存单元的地址;

    对于数据段,将它的段地址放在 DS中,用mov、add、sub等访问内存单元的指令时,CPU就将我们定义的数据段中的内容当作数据段来访问;

    在8086PC中,内存地址由段地址和偏移地址组成。

    8086CPU中有一个 DS寄存器,通常用来存放要访问的数据的段地址

    mov bx 1000H

    mov ds,bx

    mov ax,[0]    1000:0处的字型数据送入ax

    mov [0],cx       //cx中的16位数据送到 1000:0处

    SS:SP

    push、pop 实质上就是一种内存传送指令,可以在寄存器和内存之间传送数据,与mov指令不同的是,push和pop指令访问的内存单元的地址不是在指令中给出的,而是由SS:SP指出的。

    我们要十分清楚的是,push和pop指令同mov指令不同,CPU执行mov指令只需一步操作,就是传送,而执行push、pop指令却需要两步操作。

    执行push时:

    先改变SP,后向SS:SP处传送。

    执行pop时:

    先读取SS:SP处的数据,后改变SP。

    (2)push指令的执行步骤:

    1)SP=SP-2;

    2)向SS:SP指向的字单元中送入数据。

    (3)pop指令的执行步骤:

    1)从SS:SP指向的字单元中读取数据;

    2)SP=SP+2。

    我们将10000H~1FFFFH这段空间当作栈段 ,SS=1000H ,栈空间大小为64KB ,栈最底部的字单元地址为1000:FFFE。

    任意时刻,SS:SP指向栈顶,当栈中只有一个元素的时候,SS=1000H,SP=FFFEH。

    栈为空,就相当于栈中唯一的元素出栈,出栈后,SP=SP+2。

    SP原来为FFFEH,加2后SP=0,所以,当栈为空的时候,SS=1000H,SP=0。

    任意时刻,SS:SP指向栈顶元素,当栈为空的时候 ,栈中没有元素 ,也就不存在栈顶元素,所以SS:SP只能指向栈的最底部单元下面的单元 ,该单元的偏移地址为栈最底部的字单元的偏移地址+2 ,栈最底部字单元的地址为1000:FFFE,所以栈空时,SP=0000H。

    任意时刻,SS:SP指向栈顶元素。

    (5)8086CPU只记录栈顶,栈空间的大小我们要自己管理。

    对于栈段,将它的段地址放在SS中,将栈顶单元的偏移地置放在 SP 中,这样CPU在需要进行栈操作的时候,比如执行 push、pop 指令等,就将我们定义的栈段当作栈空间来用。

    相关文章

      网友评论

          本文标题:寄存器

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