有没有办法从带有 LLVM 的模块生成“纯”机器代码?
我的意思是,我有一个模块,并且只想获取没有任何 MachO 或 Darwin 对象标头的 x86 操作码,只获取操作码(如果可能,将它们重新定位到某个基地址)。
有没有办法从带有 LLVM 的模块生成“纯”机器代码?
我的意思是,我有一个模块,并且只想获取没有任何 MachO 或 Darwin 对象标头的 x86 操作码,只获取操作码(如果可能,将它们重新定位到某个基地址)。
我认为您正在寻找 objdump。利用objdump -d your_executable > dump_file
执行此类操作的“标准”方法是构建可执行文件,然后根据需要提取原始位。像http://www.bravegnu.org/gnu-eprog/hello-arm.html之类的东西。
另一种方法是使用 LLVM JIT API;不过,我没有任何好的文档或示例代码来说明如何以这种方式使用 LLVM。也许看看 lldb 中的 ClangExpressionParser::PrepareForExecution 是如何工作的(http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Expression/ClangExpressionParser.cpp?revision=161559&view=markup)。