Может ли llvm скомпилировать, собрать и связать код x86-64 в Windows и / или Linux, используя llvm-mc и lld?
Если да, то есть ли здесь пример на мировом уровне? Документация довольно скудная в настоящее время.
Я попытался создать простой привет мир (main0.cpp) с использованием транка LLVM (с помощью Clang & ДНУ).
main0.cpp:
int main(int argc, char const* argv[])
{ return 0; }
Компилировать (без ошибок):
[MY-LLVM]/clang -S -o main0.s main0.cpp
Собрать (без ошибок):
[MY-LLVM]/llvm-mc -arch=x86-64 -triple=x86_64-linux-gnu -o main0.o main0.s
Ссылка на сайт (ОШИБКИ ЗДЕСЬ!):
[MY-LLVM]/lld -flavor gnu --eh-frame-hdr -m elf_x86_64 -dynamic-linker /lib64/ld-linux-x86-64.so.2 -L/usr/lib/gcc/x86_64-linux-gnu/4.8 -L/usr/lib/x86_64-linux-gnu -L/lib/x86_64-linux-gnu -L/lib64 -L/usr/lib/x86_64-linux-gnu -L/usr/lib -L/<MY-LLVM>/lib -L/lib -L/usr/lib -lstdc++ -lm -lgcc_s -lgcc -lc -lgcc_s -lgcc /usr/lib/x86_64-linux-gnu/crt1.o /usr/lib/x86_64-linux-gnu/crti.o /usr/lib/gcc/x86_64-linux-gnu/4.8/crtbegin.o /usr/lib/gcc/x86_64-linux-gnu/4.8/crtend.o /usr/lib/x86_64-linux-gnu/crtn.o -o main0.run main.o
Ошибка ссылки:
lld: unknown input file format for file main.o
Я получил команду компоновщика через clang -o main0.run main0.cpp -###
(замена ld
с [MY-LLVM]/lld -flavor gnu
).
Я предполагаю, что я генерирую неправильный тип объектного файла при сборке или использую неправильные параметры при компоновке.
Кто-нибудь знает, как это сделать правильно?
(Моя конечная цель — получить полный C ++ 14, работающий на win64 (без массовых хаков), но я борюсь за то, чтобы магистральный лязг работал с инструментами mingw, поэтому я решил попробовать чистый LLVM).
Я разработчик здесь.
Я сам хост на Linux и Windows, поэтому я ожидаю, что они будут работать здесь. Обычно я заставляю clang использовать lld — создать символическую ссылку на lld с именем ld и добавить ее в PATH. В этом случае lld будет вести себя как gnu-ld.
Что касается llvm-mc, это не ассемблер. Это инструмент для тестирования слоя MC llvm. По умолчанию он просто анализирует сборку и выводит ее обратно. Вот почему lld отклоняет файл main0.o, так как на самом деле это текстовый файл.
Правильная вещь, которую нужно сделать здесь без lld как ld в пути:
clang -c -o main0.o main0.cpp
или же:
clang -S -o main0.s main0.cpp
clang -c -o main0.o main0.s
Если вы действительно хотите сборку по какой-то причине.