汇编语言:解读IP寄存器


前言

一、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寄存器

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值