使用LLVM工具链编译,组装和反汇编

时间:2012-01-03 19:56:16

标签: llvm

我正在尝试运行以下example来使用LLVM工具链编译,组装和反汇编一个小程序。

我的目的是了解它是如何工作的,所以在进一步的尝试中,我可以通过更改和/或重新排序assmbly的指令来进行一些性能测试。

首先,我首先得到虚拟程序的咬合代码:

    % llvm-gcc -O3 -emit-llvm hello.c -c -o hello.bc

一旦我有了咬代码,我尝试使用llvm-dis实用程序来查看LLVM汇编代码和llc,使用LLC代码生成器将程序编译回本机程序集(仅用于尝试摇动) ):

    % llvm-dis < hello.bc | less
    % llc hello.bc -o hello.s

但在这两种情况下我都会收到以下错误:

    llvm-dis: Invalid MODULE_CODE_GLOBALVAR record

关于如何解决这个问题的任何想法?

我用谷歌搜索,我还没有找到解决方案。我也尝试过使用

    otool -tV hello

但是输出与llvm不兼容。而不是获得以下汇编格式:

.section    __TEXT,__text,regular,pure_instructions
.globl  _main
.align  4, 0x90
    _main:
    Leh_func_begin1:
pushq   %rbp
    Ltmp0:
movq    %rsp, %rbp
    Ltmp1:
subq    $16, %rsp
    Ltmp2:
leaq    L_.str(%rip), %rax

我明白了:

__TEXT,__text) section
start:
0000000100000eb0    pushq   $0x00
0000000100000eb2    movq    %rsp,%rbp
0000000100000eb5    andq    $0xf0,%rsp
0000000100000eb9    movq    0x08(%rbp),%rdi
0000000100000ebd    leaq    0x10(%rbp),%rsi
0000000100000ec1    movl    %edi,%edx
0000000100000ec3    addl    $0x01,%edx

这对我来说无效,因为我用例如:

编译后一个程序集
    % gcc hello.s -o hello.native

提前致谢。

1 个答案:

答案 0 :(得分:5)

确保您的llvm-gcc版本与您安装的LLVM版本相匹配 - 二进制IR格式变化非常快,并且在多个版本中不向后兼容。

或者,您可以尝试从llvm-gcc中发出LLVM IR的 text 表示,并通过llvm-as汇编它。

这样的事情:

llvm-gcc -emit-llvm -S foo.c -o foo.ll
llvm-as foo.ll -o foo.bc
llc foo.ll -o foo.S