Компиляция, сборка и дизассемблирование с использованием цепочки инструментов LLVM

Я пытаюсь запустить следующий пример для компиляции, сборки и дизассемблирования небольшой программы с помощью инструмента LLVM цепь.

Я намерен изучить, как это работает, чтобы в дальнейших попытках я мог провести некоторый тест производительности, изменив и / или переупорядочив инструкции сборки.

Для начала я сначала получаю бит-код фиктивной программы:

    % 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

Есть идеи, как решить эту проблему?

I ' я погуглил, и я не нашел решения. Я также пробовал использовать

    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

Заранее спасибо.

6
задан gtangil 3 January 2012 в 19:56
поделиться