Я пытаюсь запустить следующий пример для компиляции, сборки и дизассемблирования небольшой программы с помощью инструмента 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
Заранее спасибо.