3

有没有办法从带有 LLVM 的模块生成“纯”机器代码?

我的意思是,我有一个模块,并且只想获取没有任何 MachO 或 Darwin 对象标头的 x86 操作码,只获取操作码(如果可能,将它们重新定位到某个基地址)。

4

2 回答 2

1

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

于 2013-03-07T08:51:36.927 回答
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)。

于 2012-08-25T07:40:10.093 回答