在OS X上通过ucontext访问EIP和EBP

opt*_*ixx 4 c linux macos freebsd

我试图将一个工具移植到osx,它设计用于在linux和freebsd上运行.程序中存在需要访问EIP和EBP的情况.这是通过ucontext完成的.

所以我为__APPLE__添加了一个案例,以便对ucontext结构进行适当的访问.

 9887 #if defined(__FreeBSD__)
 9888         *paddr = uc->uc_mcontext.mc_eip;
 9889 #elif defined(__dietlibc__)
 9890         *paddr = uc->uc_mcontext.eip;
 9891 #elif defined(__APPLE__)
 9892         *paddr = uc->uc_mcontext.ss.eip;
 9893 #else
 9894         *paddr = uc->uc_mcontext.gregs[REG_EIP];
 9895 #endif
Run Code Online (Sandbox Code Playgroud)

但是uc-> uc_mcontext.ss.eip不能编译.不确定如何从ucontext访问EIP.

Has*_*kun 6

似乎OS X 10.5中的命名方案发生了变化uc->uc_mcontext->__ss.__eip.在更高版本中,这适用uc->uc_mcontext->__ss.__rip于x86_64.

通过快速发现谷歌搜索,参考文献: 1,2