1. 概论
假设函数P调用函数Q,Q执行后返回到P。这个调用包括下面一个或多个机制:
- 传递控制:在进入过程Q的时候,PC指针被设置为Q的代码的起始地址,然后Q返回时再把PC设置为P中调用Q后面的那条指令地址。
- 传递数据:P必须能够向Q提供一个或多个参数,Q必须能够向P返回一个值。
- 分配和释放内存:Q可能需要为局部变量分配空间,返回前又必须释放这些空间。
运行时栈的结构如下图:

其中x86-64的栈向低地址方向增长,而栈指针%rsp指向栈顶元素。可以用pushq和popq将数据入栈或者出栈。
2. 传递控制
调用指令是:
| 指令 | 描述 |
|---|---|
| call Label | 过程调用 |
| call *Operand | 过程调用 |
| ret | 从过程中返回 |
实例说明:
- main函数使用call调用了multstore函数
- multstore函数调用ret返回到main函数
// Beginning of function multstore
1 00

本文深入探讨了计算机系统中x86-64架构下的函数调用过程,包括传递控制、数据传送、内存分配与释放、栈上局部存储以及寄存器中的局部存储空间。详细阐述了call指令如何改变PC指针,参数如何通过寄存器和栈传递,以及局部变量在栈和寄存器中的管理规则。
最低0.47元/天 解锁文章
323

被折叠的 条评论
为什么被折叠?



