CS和IP 是8086中两个最关键的寄存器,他们指示了cpu当前要读取指令的地方。CS为代码段寄存器,IP为指令指针寄存器
在8086pc机中,任意时刻,设CS中的内容为M,IP中的内容为N,8086CPU将从内存M*16+N单元开始,读取下一条指令
8086cpu工作的过程可以描述如下:
1:从CS:IP指向的内存单元读取指令,读取的指令进入指令缓冲器
2:IP=IP+所读取指令的长度,从而读取下一条指令
3:执行指令,转到步骤1,重复这个过程
能够改变CS IP的内容的指令被系统称为转移指令,例如JMP指令
如果想同时修改CS IP的内容,可以用“jmp段地址:偏移地址”指令完成
“jmp 段地址:偏移地址”指令的功能为:用指令中给出的段地址修改CS,偏移地址修改IP
若想仅仅修改IP的内容,可以用”jmp某一个合法的寄存器“的指令来完成
CPU提供的栈机制
8086CPU中提供入栈和出栈指令,最基本的是两个PUSH(入栈)和POP(出栈)
比如,push ax表示将寄存器ax中的数据送入栈中,pop ax表示将从栈顶取出数据送入ax,8086cpu的入栈和出栈操作都是以字为单位进行的
注意:字型数据用两个单元存放,高地址单元存放高8位,低地址单元存放低8位
在8086CPU中,有两个寄存器,段寄存器SS和寄存器SP,栈顶的段地址存放在SS中,偏移地址存放在SP中,任意时刻,SS:SP指向栈顶元素
push ax的执行,有以下两步完成
1:SP=SP-2, SS:SP指向当前栈顶前面的单元,以当前栈定前面的单元新的栈顶
2:将ax中的内容送入SS:SP指向的内存单元处,SS:SP此时指向新栈顶