2012-08-24 51 views
3

有没有一种方法可以从LLVM模块生成“纯”机器代码?我的意思是,我有一个模块,只想得到没有任何MachO或Darwin对象头的x86操作码,只是操作码(如果可能的话,让他们重新定位到某个基地址)。使用LLVM生成纯机器代码

回答

0

执行此类操作的“标准”方法是构建可执行文件,然后根据需要提取出原始位。类似于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)。

1

我认为您正在寻找objdump。 使用objdump -d your_executable > dump_file