目录
在总结generate_call_stub()保存调用者方法栈过程之前,还是先来回顾下,JVM初始化链是怎么到达该函数的。call_stub()函数里返回一个CallStub类型的函数指针,由_call_stub_entry这一基本类型转换而得到,_call_stub_entry在前面的日志里说到,它最终是unsigned int类型,存放的是某一内存地址,类型转换为CallStub后,也就是call_stub()会将返回值函数指针所存放的地址,标识的是某一个函数,直接调用。_call_stub_entry变量存放的内存地址,在JVM初始化时就会指定好,上一篇日志中给出的初始化链最后,调用了generate_initial()函数,函数内部又调用了generate_call_stub(),该函数就是对_call_stub_entry变量进行初始化。初始化过程中,需要将一些参数进行压栈,也就是保存到方法栈中,前面的日志里说到CallStub需要的参数有8个,连接器link、函数返回地址result_val_address、函数返回类型result_type,Java方法method()和entry_point例程入口等等,从generate_call_stub()函数中我们也看到了初始化参数的压栈操作。
入参位置
可以看到,在generate_call_stub()初始化时,会对一系列的参数进行定义,之后压栈,那么它们的入参位置在哪呢?从它们后面的参数可以看到,link的入参位置在rbp栈基地址寄存器往上偏移2*wordSize的地方,在32位的系统环境下,wordSize表示4个字节,64位系统下表示8个字节,以32位为例,所以第一个参数link的栈地址是8(%ebp