C语言程序过程性调用的机器级表示

C语言程序过程性调用的机器级表示,第1张

C语言程序过程性调用的机器级表示

一.过程调用的执行步骤(P为调用者,Q为被调用者)

现场:通用寄存器的内容

 二.寄存器的约定

三. 局部变量存放在另一个存储区:栈区

        全局变量和静态变量连续存放在同一个存储区:可读写数据区

        栈区的地址高

四.具体过程

准备阶段

        形成帧底:pushl  %ebp 和movl %esp, %ebp

        注:此函数ebp和调用这个函数的函数esp不是相等的

        生成栈帧(如果需要的话):subl  $24, %esp

        保存现场(如果有被调用者保存寄存器) :push指令

过程(函数)体

        分配局部变量空间,并赋值

        具体处理逻辑,如果遇到函数调用时

                准备参数:将实参送栈帧入口参数处

                CALL指令:保存返回地址并转被调用函数

                注:返回地址即为esp-4

        在EAX中准备返回参数

结束阶段

        恢复现场,释放局部变量空间

        退栈:leave指令 或 pop指令(恢复栈底,指向返回地址)

        取返回地址返回:ret指令

五.Ebp ,esp的位置如图

返回地址为call指令的下一个地址,

EBP所指的为上一个函数的ebp的值

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5658088.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存