现在来看看实际的运行时环境的实现,如下的PDF中给出了几种CPU的函数调用规范,我们现在只对ia-32进行分析
![](https://app.yinxiang.com/shard/s14/res/98052faa-5810-491f-b901-7abd90c2c47f.png?resizeSmall&width=721)
其中linkage area存放caller的下一条指令的地址
saved frame pointer:caller的stack frame的地址
saved register:存放函数调用后必须回复的寄存器的内容
local storage:存放callee的局部变量
其中parameter area是caller负责的,它需要把参数push到栈中,然后调用callee,调用操作会把caller的下一条指令push到栈中,也就是linkage area的内容,之后pc会跳转到callee的代码段,后面的内容就需要callee完成了
可以通过stack frame的正偏移和负偏移来判断是caller部分还是callee部分
call