call指令是调用函数的意思,让处理器从新的内存地址开始执行,过程使用RET来返回,让处理器回到调用点上。

call会将返回地址压入堆栈,然后再将要被调用的地址复制到IP寄存器里。当RET指令被执行的时候,就会从堆栈中弹出返回地址到IP寄存器内。

调用和返回示例

假设在 main 过程中,CALL 指令位于偏移量为 0000 0020 处。通常,这条指令需要 5 个字节的机器码,因此,下一条语句(本例中为一条 MOV 指令)就位于偏移量为 0000 0025 处:

main PROC
00000020  call MySub
00000025  mov eax,ebx

然后,假设 MySub 过程中第一条可执行指令位于偏移量 0000 0040 处:

   MySub PROC
00000040 mov eaxz edx
      .
      .
      ret
   MySub ENDP

当 CALL 指令执行时如下图所示,调用之后的地址(0000 0025)被压入堆栈,MySub 的地址加载到 EIP。

执行 MySub 中的全部指令直到 RET 指令。当执行 RET 指令时,ESP 指向的堆栈数值被弹岀到 EIP(如下图所示,步骤 1)。在步骤 2 中,ESP 的数值增加,从而指向堆栈中的前一个值(步骤 2)。

本文部分转自:http://c.biancheng.net/view/3537.html

转载请注明来源:https://longjin666.cn/?p=1304

欢迎关注我的公众号“灯珑”,让我们一起了解更多的事物~

你也可能喜欢

发表评论