寄存器

2021-09-28  本文已影响0人  flamez57

一、普通寄存器 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 指令等,就将我们定义的栈段当作栈空间来用。

上一篇下一篇

猜你喜欢

热点阅读