day18.EIP、CALL、RET指令用法

第18节: EIP、CALL、RET指令用法


前面章节我们已经学过了一些指令了如:add、push、pop等。这节我们学习一下EIP、CALL、RET指令
1、jmp指令:


eip这个寄存器为什么不叫通用寄存器,原因它里面的值,就是我们CPU下一次要执行的地址,大家前面学过的mov指令,如果要改一个通用寄存器的的值,就用如:mov eax,1,当我们在反汇编窗口写完这条指令,按F8执行完后 ,EAX的值就是00000001。那如果是mov eip,1,这样写行吗?答案是不行的。因为intel没有提供用mov修改eip的寄存器的值,如果要修改eip的值那我们就要用到jmp指令如下:


1)在反汇编窗口输入:jmp  00F01313
2)原来eip=00F012EB
3)按F8执行完后EIP的值是: 00F01313


说明要记住jmp指令仅仅是修改EIP的值,jmp指令可以是寄存器、内存和立即数。


2、call指令:


例子: 
call 004183FA


首先修改了eip的值,接着把eip当前地址的值写到下一行地址中,这就是call的本质。




3、RET指令:
add esp,4
mov eip,[esp-4]


以上简写形式就是ret。
RET指令把当前栈顶的值放到eip里,同时然esp+4。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

随行之旅

python国产化自动化

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值