我很难理解Apple ARM64 Function Calling Conventions doc和 ARM Procedure Call Standard. 当一个函数被调用时,我知道$r0是self,而$r2似乎是第一个函数参数. 什么是$x1? 堆栈指针是否引用超过四的第一个参
当一个函数被调用时,我知道$r0是self,而$r2似乎是第一个函数参数.
什么是$x1?
堆栈指针是否引用超过四的第一个参数?
您想阅读AAPCS64的“基本过程调用标准”一章,“子程序调用”部分;它们的寄存器命名约定使用“r0..r30”,其中lldb使用“x0..x30”. x1是第二个参数寄存器. x0是第一个. arm64 iOS ABI与AAPCS64的最大区别在于如何调用可变函数(printf等).您链接的苹果文档详细说明了确切的区别.lldb为armv7 / arm64 / x86_64,$argi提供寄存器别名,以引用第i个参数. $arg1,$arg2等.(在i386上的堆栈上传递参数,因此别名没有在那里定义)我建议使用这些便利名称,如果可能的话,不要担心架构的细节.
注意,这些参数传递寄存器内容仅在函数开始时有效.它们通常保存在堆栈中或复制到其他寄存器中 – 只要进行另一个函数调用,寄存器就会被重用/覆盖.