汇编04-MASM 过程调用

Qt源码解析 索引

汇编03—MASM 过程(procedure)调用

堆栈原理

32位模式运行时堆栈,在x86平台下 ,内存地址从高地址到低地址扩展。入栈操作:

  • ESP指针减4;
  • 数值复制到栈顶指针指向的堆栈位置。

应用场景:

  • 寄存器多次使用时的临时保护区与恢复;
  • 执行CALL指令,CPU在堆栈中保存当前过程调用的返回地址;
  • 过程调用,将函数参数压入堆栈进行参数传递;
  • 局部变量的临时存放区。

过程定义

lable PROC

	...
	RET
lable ENDP

过程标号lable只在过程中可见。定义全局标号,需要在名字后面加上双冒号(::).

物理原理

CALL指令将返回地址压入堆栈,将被调用过程的地址复制到指令寄存器。返回时,RET指令从堆栈把返回地址弹出到指令寄存器。

链接库

文件格式,包含已经汇编为机器码代码的过程调用。

windows说明:

  • windows的32位模式下,输入输出必须调用操作系统的函数。

版权声明:本文为xinqingwuji原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。