前言
一、IP寄存器运作过程
汇编语言的指令执行过程如下:
- CPU从CS:IP寄存器所指向的内存单元读取指令,存放到指令缓存器中
- IP=IP+所读指令的长度,从而指向下一条指令
- 执行指令缓存器中的内容,而后回到步骤1
二、为什么那样设计
先说结论,为了call指令的设计
jmp指令
jmp指令,是转移指令;可以修改CS和IP寄存器的内容
我们知道,当我们想要改变下一条需要执行的指令的位置时,需要对CS和IP寄存器进行修改
那么我们可不可以直接通过
mov cs,0
mov ip,0
这些的方式进行修改呢,答案显然是错误的
正确的修改方式如下:
想要下一条的执行的指令段地址为2000,偏移地址为0
可通过以下的命令执行:
jmp 2000:0 //修改CS的值为2000H,IP的值为0000H
jmp 寄存器 //修改IP的值为寄存器存储的值
具体的执行过程如下
这里可以看到我们针对IP寄存器进行了修改
call指令
call指令和jmp指令类似,不同的地方在于,call指令,除了会对IP寄存器进行修改的同时,也会将call指令后一条指令所位于的IP地址进行保存,而存储起来的数值,可以通过ret指令再次恢复到IP寄存器中
三、例题
答:一共进行了4次修改IP,
1.mov ax,bx读取后指令自动往下跳
2.sub ax,ax读取后指令自动往下跳
3.jmp ax读取后指令自动往下跳
4.jmp指令修改IP寄存器