我很难理解Apple
ARM64 Function Calling Conventions doc和
ARM Procedure Call Standard.
当一个函数被调用时,我知道$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上的堆栈上传递参数,因此别名没有在那里定义)我建议使用这些便利名称,如果可能的话,不要担心架构的细节.
注意,这些参数传递寄存器内容仅在函数开始时有效.它们通常保存在堆栈中或复制到其他寄存器中 – 只要进行另一个函数调用,寄存器就会被重用/覆盖.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。