第10部分-Linux x86 64位汇编 函数调用规则
汇编语言程序中创建函数需要3个步骤。
- 定义需要的输入值
- 定义对输入值执行的操作
- 定义如何生成输出值以及如何把输出值传递给发出调用的程序。
定义输入值
可以使用寄存器,全局变量或者堆栈。
使用寄存器时候要注意,如果被调用的函数修改主程序使用的寄存器,那么在被调用之前保存寄存器的当前状态,并且在函数返回之后恢复寄存器的状态。可以使用PUSH和POP,或者PUSHA和POPA。
全局变量是在内存中的位置,程序中所有函数都可以访问这些内存位置。
定义函数处理
汇编器中声明函数名称如下:
.type func1,&function
func1:
函数结束由RET指令定义,执行到RET指令时,程序控制返回主程序,返回的位置是紧跟在调用函数的CALL指令后面的指令。
和高级语言不通,可以把任意数量的函数代码放在_start之前也可以放在主程序之后。
定义输出值
和输入值类似,输出结果可以是下面两种常见的
把结果存放在一个或多个寄存器中
把结果存放在全局变量内存位置中。
访问函数
创建好函数后,就可以在程序中的任何位置进行访问。使用CALL指令用于把控制从主程序传递到函数。
call function